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

const_cast 的唯一作用是:在编译期移除指针或引用所指向对象的 const(或 volatile)限定符。它不能改变变量本身的存储属性,也不能用于普通非指针/非引用类型(比如不能对 const int x = 5; 直接 const_cast)。
什么时候允许用 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]; }
// 复用非 const 版本,避免重复逻辑
char& operator[](size_t i) {
return const_cast(
static_cast(this)->operator[](i)
);
} };
立即学习“C++免费学习笔记(深入)”;
这里先将 this 转为 const* 调用 const 版本,再用 const_cast 拆掉返回值的 const 引用——因为 data_ 本身是非 const 的,所以安全。
绝对禁止的操作
以下行为会导致未定义行为,编译可能通过,但运行结果不可预测:
- 对真正 const 定义的对象强制修改:
const int x = 10; int* p = const_cast(&x); *p = 20; - 对字面量或字符串字面量去 const:
const char* s = "hello"; char* t = const_cast(字符串字面量通常在只读段)(s); t[0] = 'H'; - 用于非指针/非引用类型转换,如
const_cast—— 编译失败(5)
替代 const_cast 的更优思路
多数想“去掉 const”的场景,其实反映的是设计问题。优先考虑:
- 是否该用两个独立接口(一个 const,一个 non-const),而非强行转?
- 能否通过 const 成员函数返回可修改的代理对象(proxy)?
- 是否误把接口 const 当成了实现限制?实际只需调整 const 正确性(比如加
mutable成员)
滥用 const_cast 往往掩盖了 const 正确性缺陷,增加维护风险。











