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

const_cast 的唯一作用是:在编译期移除指针或引用所指向对象的 const(或 volatile)限定符。它不能改变变量本身的存储属性,也不能用于普通非指针/非引用类型(比如不能对 const int x = 5; 直接 const_cast<int>(x)</int>)。
仅当原始对象**本身不是 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]; }
<pre class="brush:php;toolbar:false;">// 复用非 const 版本,避免重复逻辑
char& operator[](size_t i) {
return const_cast<char&>(
static_cast<const MyString*>(this)->operator[](i)
);
}};
立即学习“C++免费学习笔记(深入)”;
这里先将 this 转为 const* 调用 const 版本,再用 const_cast 拆掉返回值的 const 引用——因为 data_ 本身是非 const 的,所以安全。
以下行为会导致未定义行为,编译可能通过,但运行结果不可预测:
const int x = 10; int* p = const_cast<int>(&x); *p = 20;</int>
const char* s = "hello"; char* t = const_cast<char>(s); t[0] = 'H';</char>(字符串字面量通常在只读段)const_cast<int>(5)</int> —— 编译失败多数想“去掉 const”的场景,其实反映的是设计问题。优先考虑:
mutable 成员)滥用 const_cast 往往掩盖了 const 正确性缺陷,增加维护风险。
以上就是c++++ const_cast有什么用 c++去除const属性方法【详解】的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号