static const int 使用(用作函数实参)的陷阱(备考)

类静态const整型值作为函数参数时会带来undefined reference to的问题

有个函数 MyObject* MyClassA::getObject(int index) {  }

 

定义了静态变量

类头文件

const static int THIS_OBJECT_ID= 2; 

类实现

MyObject* a = factory->getObject(THIS_OBJECT_ID); //编译无错, 链接时报错

 undefined reference to `GBLaBla::THIS_OBJECT_ID'

需强制转换Int

MyObject* a = factory->getObject((int)THIS_OBJECT_ID);

 

2个小时被这个问题难住, 衰

### 静态常量整型变量 `static const int` 的用法 静态常量整型变量 (`static const int`) 是一种具有内部链接性的常量,在定义它的源文件内有效。这意味着该变量不会被其他翻译单元所访问。 #### 定义与初始化 当声明一个 `static const int` 变量时,通常会在其第一次使用之前进行初始化: ```cpp // 文件 scope.cpp #include <iostream> namespace { static const int MAX_SIZE = 100; } void printMaxSize() { std::cout << "Maximum size is: " << MAX_SIZE << std::endl; } ``` 上述代码展示了如何在一个匿名命名空间中定义并初始化了一个名为 `MAX_SIZE` 的静态常量[^1]。 #### 使用场景 ##### 函数参数传递优化 对于基本数据类型的参数,如果不需要修改,则可以考虑将其作为 `const` 参数传入,并且可以在类成员函数中设置为 `static const` 来节省内存开销: ```cpp class MyClass { public: static const int DEFAULT_VALUE; void setDefault(int& value) const { value = DEFAULT_VALUE; } }; const int MyClass::DEFAULT_VALUE = 42; // 类外初始化 ``` 这里展示了一种常见模式:将默认值设为类级别的静态常数。 ##### 编译时常量表达式 C++ 支持编译期计算,因此可以用作模板参数或数组大小等场合下的固定数值: ```cpp template<static const int N> struct ArrayWrapper { double data[N]; }; ``` 此结构体接受一个由外部指定的静态常量来决定数组的实际长度。 #### 常见错误及解决方法 尝试改变已声明为 `const` 的对象会导致编译失败;而试图通过指针间接更改则可能引发未定义行为。例如下面这段不合法的操作会触发编译器警告甚至报错: ```cpp int main(){ static const int VALUE = 98765; *(const_cast<int*>(&VALUE)) = 12345; // 不推荐的做法,可能导致程序崩溃或其他不可预测的结果 return 0; } ``` 这种做法违反了类型系统的安全性原则,应该避免这样做。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值