一尘不染

为什么const_cast没有修改调用方函数中的值?

linux

对于以下代码段,

#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是否有某种未定义的行为?


阅读 290

收藏
2020-06-03

共1个答案

一尘不染

const_cast是否有某种未定义的行为?

是的 ,您的程序包含未定义的行为。

这意味着您不能对它的输出有任何期望。原因由C ++ 11标准的7.1.6.1/4给出:

除了可以声明任何声明的类成员mutable(7.1.1)之外,在const 对象的生存期内(3.8)进行任何尝试修改都会导致未定义的行为

第5.2.11 / 7段const_cast包含进一步的警告:

[
:取决于对象的类型,通过指针,左值或指向数据成员的指针的写操作可能会产生不确定的行为(7.1.6.1)const_cast,该操作会抛弃const-qualifier。—
尾注 ]

2020-06-03