C++ 为什么打印变量的地址会在每次执行时打印随机值,即使它是C中的逻辑地址?

C++ 为什么打印变量的地址会在每次执行时打印随机值,即使它是C中的逻辑地址?,c++,c,memory,memory-management,operating-system,C++,C,Memory,Memory Management,Operating System,从这个问题: 我知道当我打印任何变量的地址时,它会打印虚拟地址。但我在书中读到过,这意味着对于每个进程,虚拟地址从0开始,MMU将实际负责地址转换 所以当我多次执行程序时,我看到一些随机地址?为什么会发生这种情况?为什么不从0开始呢?该地址是否表示与实际进程的基址之间存在某种偏移?如果是的话,这不意味着它是物理地址吗 我在POP操作系统上运行我的电脑,我的系统也是新的。 以下是每次执行时打印变量地址时的值: 0x7ffc62f83904 0x7ffd78dee214 0x7fff2b69f6c4

从这个问题:

我知道当我打印任何变量的地址时,它会打印虚拟地址。但我在书中读到过,这意味着对于每个进程,虚拟地址从0开始,MMU将实际负责地址转换

所以当我多次执行程序时,我看到一些随机地址?为什么会发生这种情况?为什么不从0开始呢?该地址是否表示与实际进程的基址之间存在某种偏移?如果是的话,这不意味着它是物理地址吗

我在POP操作系统上运行我的电脑,我的系统也是新的。 以下是每次执行时打印变量地址时的值:

0x7ffc62f83904
0x7ffd78dee214
0x7fff2b69f6c4
0x7ffcc89680a4
0x7ffdc5cbf514
0x7ffd00540714
0x7ffd743ac3d4
0x7ffe7c5a9914
0x7ffd1ea1d214
0x7ffe21c30d64
0x7ffe885d9de4
0x7ffc5d8432e4
0x7ffe87ebff04
0x7ffc726e88d4
0x7ffef650e684
0x7fff0a62a2f4
0x7ffe89e3aed4
0x7ffd77e596f4
0x7ffcfcf76c54
0x7fff9a2cf654
0x7ffe3a8cbf84
0x7ffc4e127704
0x7ffce1a9f894
0x7ffd908828a4
0x7ffc88b0c6b4
0x7ffc2dd04804
0x7ffda3991c24
0x7fffad288da4
0x7ffd34da2994
0x7ffc3e3dcf54
0x7ffc6780b224
0x7ffee8f41554
0x7ffd369d9c54
0x7ffe5bdfca14
0x7ffc9a772454
0x7ffe03665d04
0x7ffce0eeb234
0x7ffc4fad04a4
0x7ffea8c715e4
0x7ffc6c3eb7f4
0x7ffea32a5e24
0x7ffea7729394
0x7ffdfbd2eab4
0x7fff36934134
0x7ffe9e15b1e4
0x7ffe12a07194
0x7ffc1b2fce34
0x7ffc3a82b684
0x7ffe56aad1d4
0x7ffd00d59c54
0x7fff58636474
0x7ffdc8940964
0x7ffed8146aa4
0x7ffd81794c94
0x7ffdce6ac874
0x7fff761a79c4
0x7ffe8fc95a24
0x7ffd3fb95464
0x7ffdbceeeb84
0x7ffc1582c2d4
0x7ffd47f0e8b4
0x7ffdd55b12f4
0x7ffc802a3db4
0x7ffebe9634a4
0x7ffec809acf4
0x7ffd0dfe0354
0x7ffc80eeb8d4
0x7fff1914b3b4
0x7fff3fee60d4
0x7ffccf1febf4
0x7ffdfe68c264
0x7ffd631c8184
0x7ffd814bc3c4
0x7ffc53a2d3d4
0x7fff49d96e14
0x7ffc16144e14
0x7ffecfe11904
0x7ffeaa3dc584
0x7ffcfb3a2894
0x7fff8a6a04b4
0x7ffcf0e035f4
0x7ffe060a7654
0x7ffce2a00954
0x7ffcc81980f4
0x7ffc0c706034
0x7fff172e4f34
0x7ffd62c963e4
0x7ffcf00501a4
0x7ffeec50b044
0x7ffd0bbb2be4
0x7ffff8fbebf4
0x7ffd6e127ac4
0x7fff0f2b9714
0x7ffe8b6da014
0x7ffc58f83344
0x7ffc3aa463e4
0x7fff8b28c9d4
0x7ffe1799f8a4
0x7fffe398f734
0x7fffb3056f74
它是否应该包含重复的内容?
现在,如果我并行运行同一个程序多次,确认它是一个虚拟地址而不是物理地址,它是否会包含重复的地址?

那么每次编译时,地址都应该是相同的(例如0x28fefc)。不,它不应该从0开始,因为MMU进行转换

请使用此代码重试,并查看其是否有效:

#包括
使用名称空间std;
int main(){
int n;

cout否,虚拟地址不需要从零开始,通常也不需要从零开始。每个操作系统、程序加载器和/或链接器都有一些默认的内存布局。通常在地址零处没有映射任何内容,因此零可以充当空指针,并在取消引用时导致故障。通常堆栈在内存中的位置较高,但通过随机偏移量进行调整,以抵御依赖固定或已知地址的攻击。这就是导致您看到的变化的原因。

您确定它是随机的吗?您可以共享您的打印吗?如果您在pc上运行,您可能有MMU和虚拟地址。请参阅此链接: