写这篇博客的初衷是我再整理图书的时候翻到一本介绍Linux的书上有介绍size命令.
size命令的输出不包括stack和heap的部分。只包括文本段(text), 代码段(data),未初始化数据段(bss)三部分。
示例:
vi hello.c
#include<stdio.h>
int main()
{
return 0;
}
wq保存之后,输入gcc -o a.out hello.c
[root@centos-linux ~]# size a.out
text data bss dec hex filename
1129 540 4 1673 689 a.out
[root@centos-linux ~]# size
text data bss dec hex filename
1129 540 4 1673 689 a.out
当不输入目标文件时,将会把a.out文件作为缺省输入文件名.
dec和hex分别是10进制和16进制表现形式,值是text data bss三者相加的总和。
1、文本段(text):包含程序的指令,它在程序的执行过程中一般不会改变。文本段通常被称为代码段。
2、数据段(data):包含了经过初始化的全局变量和局部静态变量。
3、BSS段(bss):包含未经初始化的全局变量和静态变量。
4、堆栈段:包含了函数内部声明的局部变量。
在本文中我们验证C语言中变量分别位于哪:
未初始化的全局变量
#include<stdio.h>
int global;
int main()
{
return 0;
}
然后执行gcc -o a.out hello.c
[root@centos-linux ~]# vi hello.c
[root@centos-linux ~]# gcc -o a.out hello.c
[root@centos-linux ~]# size
text data bss dec hex filename
1129 540 12 1681 691 a.out
我们可以看到bss字段由之前的4变为现在的12,
未初始化的静态变量
vi hello.c
#include<stdio.h>
int main()
{
static int a;
return 0;
}
执行相同操作我们可以验证上述第3条结论:BSS段(bss):包含未经初始化的全局变量和静态变量。
其它结论同样可以验证,在此不一一赘述。
文章结尾附上一道与内存布局相关的思考题供各位思考.
如下代码的输出是什么?
#include<stdio.h>
int main()
{
char a=0;
char b=0;
int *p=(int *)&b;
*p=258;
printf("%d %d",a,b);
return 0;
}