为什么const_cast会不会修改调用函数的值?(Why const_cast is not mo

2019-09-02 16:53发布

对于下面的代码片段,

#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

为什么a的值不被修改,即使我试图修改它的乐趣()?

怎么来的地址和指针z是相同的,但值是不同的?

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

Answer 1:

它是某种具有的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)。 - 注完 ]



文章来源: Why const_cast is not modifying the value in caller function?
标签: c++ linux const