对于以下代码段,
#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是否有某种未定义的行为?
是的 ,您的程序包含未定义的行为。
这意味着您不能对它的输出有任何期望。原因由C ++ 11标准的7.1.6.1/4给出:
除了可以声明任何声明的类成员mutable(7.1.1)之外,在const 对象的生存期内(3.8)进行任何尝试修改都会导致未定义的行为
mutable
const
第5.2.11 / 7段const_cast包含进一步的警告:
const_cast
[ 注 :取决于对象的类型,通过指针,左值或指向数据成员的指针的写操作可能会产生不确定的行为(7.1.6.1)const_cast,该操作会抛弃const-qualifier。— 尾注 ]