对于以下片段,
#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;
}
Run Code Online (Sandbox Code Playgroud)
产生的产量是
q: 0x7fff65910fcc Value: 100
z: 0x7fff65910fcc Address of a: 0x7fff65910fcc
value at z: 100 value in a: 10
Run Code Online (Sandbox Code Playgroud)
为什么即使我试图在fun()中修改它,a的值也没有被修改?
为什么a和指针z的地址相同但值不同?
是const_cast的某种未定义行为吗?
And*_*owl 10
是const_cast的某种未定义行为吗?
是的,您的程序包含未定义的行为.
这意味着您对其输出不能有任何期望.原因在于C++ 11标准的第7.1.6.1/4段:
除了
mutable可以修改声明的任何类成员(7.1.1)之外,任何const在其生命周期内修改对象的尝试(3.8)都会导致未定义的行为
关于第5.2.11/7段const_cast的进一步警告:
[ 注意:根据对象,通过指针,左值或指针数据成员从一个产生的写操作的类型
const_cast即擅自抛弃一个const-qualifier可能会产生不确定的行为(7.1.6.1).- 结束说明 ]