C++的const_cast

使用总结:

规则1.使用const_cast的对象本身就是const,使用const_cast之后还是不可修改,如果修改会发生未定义错误

规则2.使用对象本身不是const,但后续因为某些原因转为const,使用const_cast之后可以修改

使用实例

1.与旧的(不完善的)API交互

cpp 复制代码
#include<iostream>
void legacy_c_function(char* str) {
    printf("String: %s\n", str);
}
int main(){

	const char* my_message = "Hello, world!";
    
    // 直接调用会报错:cannot convert 'const char*' to 'char*'
    legacy_c_function(my_message); 
    
    // 我们确信函数是安全的,所以使用const_cast
    legacy_c_function(const_cast<char*>(my_message)); // OK
}

在保证调用之后不会修改值时,可以使用const_cast,满足规则1

2.后来加上的const

cpp 复制代码
#include <iostream>

// 这个函数接受一个常量指针,但我们可能需要在一个非const的上下文中使用它
void processData(const int* ptr) {
    std::cout << "只读处理, 值为: " << *ptr << std::endl;

    // 假设我们现在需要调用一个只接受 non-const 指针的旧API
    // 并且我们100%确定这个旧API不会修改数据
    // void legacy_api(int* data);

    // 为了调用它,我们需要去掉ptr的const属性
    int* non_const_ptr = const_cast<int*>(ptr);
    
    // 我们现在可以通过 non_const_ptr 修改数据
    *non_const_ptr = 100; // 这是安全的!
}

int main() {
    int my_value = 50; // my_value 本身不是 const

    // processData 接收 const int*,所以 my_value 的地址被隐式转换为 const int*
    // 这里的 const 是"后来加上"的
    processData(&my_value); 

    // 检查 my_value 的值
    std::cout << "main函数中, my_value 的值现在是: " << my_value << std::endl;
}

因为my_value变量本身在main函数中被定义时是int,不是const int。它存储在可读写的内存区域。processData函数只是通过一个const指针"看待"它,限制了在该函数内的直接修改。我们使用const_cast只是"恢复"了它本来的可写属性。

相关推荐
漂流瓶jz4 小时前
总结CSS组件化演进之路:命名规范/CSS Modules/CSS in JS/原子化CSS
前端·javascript·css
踩着两条虫5 小时前
「AI + 低代码」的可视化设计器
开发语言·前端·低代码·设计模式·架构
JoneBB5 小时前
ABAP Webservice连接
运维·开发语言·数据库·学习
Jagger_5 小时前
项目上线忙碌结束之后,为什么总想找点事做?
前端
GalenZhang8885 小时前
OpenClaw 配置多个飞书账号实战指南
前端·chrome·飞书·openclaw
即使再小的船也能远航5 小时前
【Python】安装
开发语言·python
Irissgwe5 小时前
类与对象(三)
开发语言·c++·类和对象·友元
steven~~~6 小时前
为什么mq报错
javascript
雪度娃娃6 小时前
转向现代C++——优先选用nullptr而不是0和NULL
开发语言·c++
萌新小码农‍6 小时前
python装饰器
开发语言·前端·python