对于以下代码段,
#include <iostream>
using namespace std;
void fun(const int *p)
{
int *q = const_cast<int *>(p);
*q = *q * 10;
cout<<"q: "<<q<<"\t Value: "<<*q<<endl;
}
int main()
{
const int a = 10;
const int *z = &a;
fun(z);
cout<<"z: "<<z<<"\t"<<"Address of a: "<<&a<<endl;
cout<<"value at z: "<<*z<<"\t\t value in a: "<<a<<endl;
}
产生的输出是
q: 0x7fff65910fcc Value: 100
z: 0x7fff65910fcc Address of a: 0x7fff65910fcc
value at z: 100 value in a: 10
为什么即使我试图在fun()中修改它,a的值也没有被修改?
为什么a和指针z的地址相同但值不同?
使用const_cast是否存在某种未定义的行为?
答案 0 :(得分:10)
使用const_cast是否存在某种未定义的行为?
是,您的程序包含未定义的行为。
这意味着您对其输出没有任何期望。原因在于C ++ 11标准的第7.1.6.1/4段:
除了可以修改声明
mutable
(7.1.1)的任何类成员之外,任何修改const
的尝试都是如此 对象在其生命周期(3.8)中导致未定义的行为
关于const_cast
的第5.2.11 / 7段包含进一步的警告:
[注意:根据对象的类型,通过指针,左值或指针进行写操作 从
const_cast
生成的数据成员转出const
- 限定符可能会产生未定义 行为(7.1.6.1)。 - 结束记录]