精选推荐

最新动态

C++怎么使用委托_C++函数对象与回调【灵活】

它不是万能胶,但比裸函数指针灵活得多。std::function 的模板参数决定了它能绑定什么签名的可调用对象。比如 std::function<void></void> 只接受能以一个 int 参数调用、返回 void 的东西。

C++怎么使用多态_C++虚函数与继承详解【运行】

不加 virtual,哪怕子类写了同名函数,调用时也完全不会走多态——编译器直接按指针/引用的静态类型决定调用哪个函数。这是最常踩的坑:以为“名字一样+继承了”就自动多态,结果 Base* p = new Derived(); p->func(); 调的还是 Base::func()。

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),也不会管理内存生命周期。