为什么全局变量存储在堆中?

Why global variables are stored in heap?

为什么在下面的例子中全局变量存储在堆段,而不是data/bss段?

从地图伪文件的以下输出中,data/bss 段是第 3 行。这是因为它是 read/write,并且是匿名的。以下 2 个条目是堆(如标签所示)。

这是 /proc//maps 的输出:

00400000-00405000 r-xp 00000000 08:02 17962770                       myexec
00604000-00605000 r--p 00004000 08:02 17962770                       myexec
00605000-00606000 rw-p 00005000 08:02 17962770                       myexec
00606000-00607000 rw-p 00000000 00:00 0                              [heap]
00607000-00642000 rw-p 00000000 00:00 0                              [heap]
7ffff7a15000-7ffff7bd0000 r-xp 00000000 08:02 22282470               ..libc2.19.so
7ffff7bd0000-7ffff7dcf000 ---p 001bb000 08:02 22282470               ..libc-.19.so
7ffff7dcf000-7ffff7dd3000 r--p 001ba000 08:02 22282470               ..libc-.19.so
7ffff7dd3000-7ffff7dd5000 rw-p 001be000 08:02 22282470               ..libc-.19.so
7ffff7dd5000-7ffff7dda000 rw-p 00000000 00:00 0 
7ffff7dda000-7ffff7dfd000 r-xp 00000000 08:02 22282466               ..ld-2.19.so
7ffff7fec000-7ffff7fef000 rw-p 00000000 00:00 0 
7ffff7ff6000-7ffff7ff7000 rw-p 00000000 00:00 0 
7ffff7ff7000-7ffff7ffa000 rw-p 00000000 00:00 0 
7ffff7ffa000-7ffff7ffc000 r-xp 00000000 00:00 0                       [vdso]
7ffff7ffc000-7ffff7ffd000 r--p 00022000 08:02 22282466                ..ld-2.19.so
7ffff7ffd000-7ffff7ffe000 rw-p 00023000 08:02 22282466                ..ld-2.19.so
7ffff7ffe000-7ffff7fff000 rw-p 00000000 00:00 0 
7ffffffde000-7ffffffff000 rw-p 00000000 00:00 0                       [stack]
ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0               [vsyscall]

但是,当我打印 2 个全局变量的位置时,我得到以下属于堆 vm 区域的地址:

glb1:6061b0 glb2:6061c0

我使用以下方式打印位置:

printf("glb1:%lx glb2:%lx\n", (uint64_t) &glb1, (uint64_t) &glb2);

BSS/DATA 是具有所有全局定义变量的段,默认情况下初始化为特定值或零。该段是可执行映像的一部分。

堆 "segment" 只是将在程序加载时分配的 数量 的额外存储空间。它不包含在图像中。此金额位于 BSS/DATA 段的末尾。

因此BSS/DATA和堆段有相同的基地址。将堆段视为 virtual/as 图像 bss/data 段的虚拟扩展。

最后,请注意通常堆栈 "segment" 会再次添加到此数量,并且在堆增长的同时,堆栈也会下降。 (这可能取决于编译器。)