据我所知,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

我无法理解为什么



因为我没有声明/初始化任何全局/静态变量?

最佳答案

在带有 gcc 的 Windows 上情况更糟:

主文件:

#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 初始化的库。

在 Windows 上使用 -nostartfiles 可以获得更好的结果。您也可以尝试使用 -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:

主文件:
#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

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

关于c - 为什么BSS段默认是 "16"?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/28962014/

10-16 11:25