为什么在以下示例中,全局变量存储在堆段中,而不是存储在data / bss段中?
从map伪文件的以下输出中,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);
答案 0 :(得分:3)
BSS / DATA是包含所有全局定义变量的段,默认情况下初始化为特定值或零。该段是可执行映像的一部分。
堆"段"只是在程序加载时分配的额外存储的金额。它不包含在图像中。该数量在BSS / DATA段结束时跟随。
因此BSS / DATA和堆段具有相同的基址。将堆段视为虚拟/作为映像的bss /数据段的虚拟扩展。
最后,请注意堆栈"段"再次添加到此数量,并且堆增长,堆栈增长。 (这可能与编译器有关。)