首先编译生成可执行文件,假如源文件名为test.c,那么
gcc -o test test.c
生成可执行文件test。
然后用命令size test查看该可执行二进制文件的基本情况
[lll@localhost code]$ size test
text data bss dec hex filename
1256 548 12 1816 718 test
代码区 静态数据/全局初始化数据区 未初始化数据区 十进制总和 十六进制总和 文件名
在没有运行程序之前,也就是说程序还没有加载到内存前,可执行程序内部已经分好3段信息,分别为代码区(多次运行可共享,只读),数据区和未初始化数据区(有些人直接把data和bss合起来叫做静态区或全局区)。代码区和全局区的大小已经固定。
运行可执行程序,操作系统把物理硬盘程序load到内存中,除了根据可执行程序的信息分出代码区、数据区和未初始化数据区之外,还增加了栈区和堆区。
栈区(stack):是一种后进先出的数据结构,由编译器自动分配释放,存放函数的参数值、返回值、局部变量等。在程序运行过程中实时加载和释放。因此,局部变量的生存周期为申请到释放该段栈空间。
堆区:堆是一个大容器,它的容量要远远大于栈,用于动态内存分配。堆在内存中位于BSS区和栈区之间,一般由程序员分配和释放,若程序员不释放,程序结束时由操作系统回收。
全局静态区:全局区、静态区、常量区(“hello world”字符串常量或const修饰的全局变量)
常量区的数据一旦初始化,不能修改,只读的内存。
char *p = “hello world”;