头文件里直接定义 int global_count = 0;,被多个 .cpp 包含就会链接失败:multiple definition of ‘global_count’。C++17 引入 inline 变量,让这种定义在多个编译单元中合法共存——它不是“内联函数”那种优化语义,而是告诉链接器:“这些同名定义是等价的,只留一个”。
成员变量
精选推荐
c++ mutable关键字有什么用 c++在const函数中修改成员【详解】
c++移动语义如何避免不必要的拷贝 c++右值引用性能优化【核心】
最新动态
C++ inline 变量是什么?(如何在头文件中直接定义全局变量)
C++怎么使用委托_C++函数对象与回调【灵活】
它不是万能胶,但比裸函数指针灵活得多。std::function 的模板参数决定了它能绑定什么签名的可调用对象。比如 std::function<void></void> 只接受能以一个 int 参数调用、返回 void 的东西。
C++怎么使用shared_ptr_C++资源管理教程【共享】
不会崩溃,但容易误以为“安全”而忽略后续解引用风险。std::shared_ptr<int> p(nullptr)</int> 是合法的,p 确实持有空指针、引用计数为 1,但一旦写 *p 或 p->xxx 就触发未定义行为(通常是段错误)。
C++中如何通过宏定义与模板结合实现简单的反射系统?(元编程实践)
因为 __FUNCTION__ 只返回函数名(如 "foo"),而 __PRETTY_FUNCTION__ 在 GCC/Clang 下会给出完整签名(如 "void foo<int>() [with T = int]"</int>),这是手动解析类型的唯一可行入口。MSVC 用 __FUNCSIG__,行为类似,但字符串格式不同——跨平台时必须分支处理。
C++怎么实现泛型算法_C++模板函数教程【复用】
因为 std::function 带运行时开销,且无法推导重载函数、函数模板或临时 lambda 的完整类型。泛型算法依赖编译期类型推导来适配任意可调用对象,而 std::function 会擦除类型信息,导致无法匹配重载、丢失 constexpr 能力,甚至让 SFINAE 失效。
C++怎么使用纯虚函数_C++抽象类教程【接口】
纯虚函数不是“必须写实现”,而是“必须在派生类里实现”,声明时用 = 0 结尾,且不能有函数体。常见错误是加了花括号、写了空实现,或者漏掉 = 0 导致编译器不认为它是纯虚函数。
如何在 RxJS 订阅外部 API 后安全使用返回数据
本文详解 angular 中因异步订阅导致 `data` 为 `undefined` 的根本原因,并提供两种可靠解决方案:在 `subscribe` 内部调用后续逻辑,或改用 `promise` + `async/await` 实现同步化控制流。
c++ auto关键字用法_c++类型推导教程
在函数参数、模板形参、类成员变量、返回类型(C++11/14 中)这些位置,auto 直接写上去会编译失败。它只用于变量定义时的类型推导,不是万能占位符。
c++移动语义如何避免不必要的拷贝 c++右值引用性能优化【核心】
移动语义的核心目标,是用“搬走资源”代替“复制资源”,从而避免深拷贝开销。关键不在于写几个 std::move,而在于识别可移动的右值、正确声明移动构造函数/移动赋值运算符,并让编译器有机会自动调用它们。
c++ mutable关键字有什么用 c++在const函数中修改成员【详解】
mutable 关键字允许在 const 成员函数中修改特定成员变量,它绕过 const 限定的“逻辑不变性”约束,但不破坏对象的物理 const 性。