它不是万能胶,但比裸函数指针灵活得多。std::function 的模板参数决定了它能绑定什么签名的可调用对象。比如 std::function<void></void> 只接受能以一个 int 参数调用、返回 void 的东西。
虚函数
精选推荐
C++怎么实现递归_C++递归算法教程【逻辑】
c++如何进行对象序列化为二进制_c++ 结构体内存导出与文件存储【实战】
最新动态
C++怎么使用委托_C++函数对象与回调【灵活】
C++怎么使用多态_C++虚函数与继承详解【运行】
不加 virtual,哪怕子类写了同名函数,调用时也完全不会走多态——编译器直接按指针/引用的静态类型决定调用哪个函数。这是最常踩的坑:以为“名字一样+继承了”就自动多态,结果 Base* p = new Derived(); p->func(); 调的还是 Base::func()。
C++中的强制类型转换(static_cast/dynamic_cast)是什么?(如何选择)
当你需要显式、安全的编译期类型转换时,static_cast 是首选。它只允许逻辑上合理的转换,比如数值类型间转换、有继承关系的指针/引用向上转型(子类 → 父类),或调用自定义转换函数。
C++如何实现无锁栈(Lock-Free Stack)?(CAS操作示例)
因为 C++ 标准不保证 std::atomic<t></t> 对任意自定义类型 T 的 CAS 操作是 lock-free 的,尤其当 T 含有非平凡析构函数或对齐要求时,is_lock_free() 很可能返回 false。底层可能退化为互斥锁模拟,彻底失去无锁意义。
C++怎么使用异常规范_C++noexcept与throw对比【安全】
你写 void f() noexcept,编译器在函数调用点就敢做优化(比如省掉栈展开逻辑);而 void f() throw() 只在运行时抛异常才触发终止——但 C++17 起它已被标记为 deprecated,连 clang 15 都会警告。实际项目里混用两者会导致链接失败或 ABI 不兼容,尤其在跨编译单元调用时。
C++怎么实现递归_C++递归算法教程【逻辑】
C++ 里递归没写好,main 都没机会输出错误信息,程序就 Segmentation fault 或 stack overflow 了。根本原因不是逻辑错,是调用栈压得太深——每次递归都占一份栈空间,而默认线程栈通常只有 1~8MB。
C++怎么实现字节序转换_C++网络字节序与主机序【通信】
因为 htonl 和 ntohl 只处理 32 位整数,底层是对 uint32_t 的字节翻转。把 float 强转成 uint32_t* 再传进去,看似能用,但实际依赖 IEEE 754 布局和平台对齐,且不保证符号/指数/尾数字段的翻转逻辑符合浮点语义——它只是“碰巧”在多数 x86/x64 上工作,但属于未定义行为。
C++怎么使用纯虚函数_C++抽象类教程【接口】
纯虚函数不是“必须写实现”,而是“必须在派生类里实现”,声明时用 = 0 结尾,且不能有函数体。常见错误是加了花括号、写了空实现,或者漏掉 = 0 导致编译器不认为它是纯虚函数。
C++怎么使用placement new_C++定位new操作详解【内存】
placement new 不是“另一种 new”,而是 operator new 的重载形式,它不分配内存,只在已有的内存地址上构造对象。你不能用它替代 new 去申请堆内存——它根本不会调用 ::operator new(size_t),也不会管理内存生命周期。
C++中的多态是如何分类的?(函数重载的静态多态与虚函数的动态多态)
函数重载(overload)不是真正意义上的“多态”语义,而是编译器根据实参类型在编译时选择具体函数版本。它不涉及继承或运行时决策,只是名字空间内多个同名函数的共存。