1

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

从 maps 伪文件的以下输出来看,data/bss 段是第 3 行。这是因为它是读/写和匿名的。以下 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);
4

1 回答 1

3

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

堆“段”只是在程序加载时分配的额外存储量它不包含在图像中。这个数量在 BSS/DATA 段的末尾。

因此 BSS/DATA 和堆段具有相同的基地址。将堆段视为虚拟/作为映像的 bss/数据段的虚拟扩展。

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

于 2015-04-16T19:09:16.073 回答