Two different values at the same memory address(同一内存地址的两个不同值)
问题描述
代码
#include 使用命名空间标准;int main() {const int N = 22;int * pN = const_cast(&N);*pN = 33;cout<<N<<' ' <<&N <<结束;cout<<*pN<<' ' <<pN<<结束;} 输出
<块引用>22 0x22ff74
33 0x22ff74
为什么同一个地址有两个不同的值?
为什么同一个地址有两个不同的数据?
没有.编译器可以优化任何对 const 的提及,就好像您在其中写入了它的编译时值一样.
请注意,如果您做了一些讨厌的技巧,例如写入为常量保留的内存,编译器也可以生成在您运行时擦除硬盘的代码.
Code
#include <iostream>
using namespace std;
int main() {
const int N = 22;
int * pN = const_cast<int*>(&N);
*pN = 33;
cout << N << ' ' << &N << endl;
cout << *pN << ' ' << pN << endl;
}
Output
22 0x22ff74
33 0x22ff74
Why are there two different values at the same address?
Why are there two different datas at the same address?
There aren't. The compiler is allowed to optimize any mention of a const to be as though you had written its compile-time value in there.
Note that the compiler is also allowed to generate code that erases your hard disk when you run it if you do nasty tricks like writing to memory reserved for consts.
这篇关于同一内存地址的两个不同值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:同一内存地址的两个不同值
基础教程推荐
- GDB 显示调用堆栈上函数地址的当前编译二进制文 2022-09-05
- 如果我为无符号变量分配负值会发生什么? 2022-01-01
- 我应该对 C++ 中的成员变量和函数参数使用相同的名称吗? 2021-01-01
- 为什么派生模板类不能访问基模板类的标识符? 2021-01-01
- CString 到 char* 2021-01-01
- 初始化列表*参数*评估顺序 2021-01-01
- 为什么 typeid.name() 使用 GCC 返回奇怪的字符以及如 2022-09-16
- 为什么 RegOpenKeyEx() 在 Vista 64 位上返回错误代码 2021-01-01
- 非静态 const 成员,不能使用默认赋值运算符 2022-10-09
- 通过引用传递 C++ 迭代器有什么问题? 2022-01-01
