C++中强制变换之const_cast

今天学习了一下C++中的强制转换,看了const_cast,我发现了这个转换关键字的奇怪之处,于是把它记录一下,废话不说,先看一个程序:

 1 #include <iostream>

 2 

 3 using namespace std;

 4 

 5 int main()

 6 {

 7     const int val = 5;

 8     int test =5;

 9     //int *pval = &val;    //err: cannot convert from 'const int * to int *'

10     int *pval = const_cast<int *>(&val);

11     cout << "Before:" << endl;

12     cout << "  val:" << val << endl;

13     cout << "*pval:" << *pval << endl;

14     *pval = 10;

15     cout << "After:" << endl;

16     cout << "  val:" << val << endl;

17     cout << "*pval:" << *pval << endl;

18     return 0;

19 }

以上程序打印的结果:

C++中强制变换之const_cast

一开始 *pval 和val的值都是5,因为他们指向同一地址。

C++中强制变换之const_cast

但是后来我通过给(*pval)赋值,是的指针pval所指向的内存地址为10,然后打印去而发现val 还是等于 5 而*pval却等于10,这是很矛盾的啊,按理讲他们是内存中同一块地址中的内容,应该完全一样啊,我很不解,于是我看了一下内存:

C++中强制变换之const_cast

以上图中的地址就是val的内存地址,但是通过上面的图可以看到,0012FF44地址处的值为 0000000A(16进制,4个字节) = 10 (十进制)。

也就是说内存中的内容确实被改变了,只是编译器在输出const int val时并不是读取内存地址内容!为了搞懂这个问题我又汇编了一下:

发现在输出val值得过程中,编译器直接将5赋值给val,而不是工内存中读取。这就解释了为什么指向内存中同一个地址,输出的值却不同!

 

 

你可能感兴趣的:(Const)