C++中强制变换之const_cast

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

 #include <iostream>

 using namespace std;

 int main()
{
const int val = ;
int test =;
//int *pval = &val; //err: cannot convert from 'const int * to int *'
int *pval = const_cast<int *>(&val);
cout << "Before:" << endl;
cout << " val:" << val << endl;
cout << "*pval:" << *pval << endl;
*pval = ;
cout << "After:" << endl;
cout << " val:" << val << endl;
cout << "*pval:" << *pval << endl;
return ;
}

以上程序打印的结果:

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时并不是读取内存地址内容!为了搞懂这个问题我又汇编了一下:

C++中强制变换之const_cast

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

C++中强制变换之const_cast
上一篇:js通过a链接控制多个DIV只显示其中一个其它隐藏


下一篇:Python之socketserver模块和验证客户端链接的合法性