const_cast仅用于编译期移除指针或引用的const/volatile限定符,且仅当原对象非const定义时才安全;禁止修改真正const对象、字面量或用于非指针/引用类型。
const_cast 的唯一作用是:在编译期移除指针或引用所指向对象的 const(或 volatile)限定符。它不能改变变量本身的存储属性,也不能用于普通非指针/非引用类型(比如不能对 const int x = 5; 直接 const_cast)。
仅当原始对象**本身不是 const 定义的**时,用 const_cast 去掉 const 才是安全且合法的。否则属于未定义行为(UB)。
const T*,但你清楚传入的实际对象是非 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]; }
// 复用非 const 版本,避免重复逻辑
char& operator[](size_t i) {
return const_cast(
static_cast(this)->operator[](i)
);
} };
这里先将 this 转为 const* 调用 const 版本,再用 const_cast 拆掉返回值的 const 引用——因为 data_ 本身是非 const 的,所以安全。
绝对禁止的操作
以下行为会导致未定义行为,编译可能通过,但运行结果不可预测:
const int x = 10; int* p = const_cast(&x); *p = 20;
c
onst char* s = "hello"; char* t = const_cast(s); t[0] = 'H'; (字符串字面量通常在只读段)const_cast(5) —— 编译失败多数想“去掉 const”的场景,其实反映的是设计问题。优先考虑:
mutable 成员)滥用 const_cast 往往掩盖了 const 正确性缺陷,增加维护风险。