const_cast仅用于编译期移除指针或引用的const/volatile限定符,且仅当原对象非const定义时才安全;禁止修改真正const对象、字面量或用于非指针/引用类型。

const_cast 的唯一作用是:在编译期移除指针或引用所指向对象的 const(或 volatile)限定符。它不能改变变量本身的存储属性,也不能用于普通非指针/非引用类型(比如不能对 const int x = 5; 直接 const_cast<int>(x)</int>)。
什么时候允许用 const_cast?
仅当原始对象**本身不是 const 定义的**时,用 const_cast 去掉 const 才是安全且合法的。否则属于未定义行为(UB)。
- 函数参数是
const T*,但你清楚传入的实际对象是非 const 的(例如内部缓存、封装接口等) - 调用第三方库中只提供 const 版本接口,但你知道底层数据可修改(需确认文档或源码)
- 实现 const 与非 const 成员函数的代码复用(常见于容器类的
operator[])
典型安全用法示例
下面这段代码是标准写法,也是 const_cast 最正当的用途之一:
class MyString {
public:
char& operator[](size_t i) { return data_[i]; }
const char& operator[](size_t i) const { return data_[i]; }
<pre class="brush:php;toolbar:false;">// 复用非 const 版本,避免重复逻辑
char& operator[](size_t i) {
return const_cast<char&>(
static_cast<const MyString*>(this)->operator[](i)
);
}登录后复制
};
立即学习“C++免费学习笔记(深入)”;
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~