c – 为什么BSS段默认为“16”?

据我所知,c程序的细分是:

        High address
|---------------------------|
|env/cmd line args vars     |
|---------------------------|
|      stack segment        |--> uninitialized auto vars
|---------------------------|
|---------------------------|
|---------------------------|
|      heap segment         |--> dynamic allocated memory
|---------------------------|
|      BSS segment          |--> uninitialized static/global vars
|---------------------------|
|      data segment         |--> initialized static/global vars
|---------------------------|
|      text segment         |--> initialized auto vars/exec instructions
|---------------------------|
        Low address

在我的RHEL 5.4 64位机器上,用于以下c程序

#include <stdio.h>
int main()
{
}

当我做:

# size a.out
   text    data     bss     dec     hex filename
   1259     540      16    1815     717 a.out

我无法理解为什么

bss=16

因为我没有宣布/初始化任何全球/静态变量?

最佳答案 在使用gcc的Windows上情况更糟:

main.c中:

#include <stdio.h>

int main( int argc, char* argv[] )
{
    return 0;
}

编译:

C:\>gcc main.c

尺寸:

C:\>size a.exe
   text    data     bss     dec     hex filename
   6936    1580    1004    9520    2530 a.exe

bss包括整个链接的可执行文件,在这种情况下链接各种库,其中使用静态c初始化.

使用-nostartfiles可以在Windows上获得更好的结果.您也可以尝试使用-nostdlib和-nodefaultlibs

编译:

C:\>gcc -nostartfiles main.c

尺寸:

C:\>size a.exe
   text    data     bss     dec     hex filename
    488     156      32     676     2a4 a.exe

删除所有库(包括c库)并获得一个“可执行文件”,其中包含您编译的内容和bss大小为0:

main.c中:

#include <stdio.h>

int _main( int argc, char* argv[] )
{
    return 0;
}

编译:

C:\>gcc -nostartfiles -nostdlib -nodefaultlibs main.c

尺寸:

C:\>size a.exe
   text    data     bss     dec     hex filename
     28      20       0      48      30 a.exe

但是,可执行文件不会运行!

点赞