- 进程中内存的分布
进程的地址空间由可寻址的虚拟内存组成,虚拟内存技术的实现方法在以后解释。地址由低到高依次是文本段--> 数据和BBS段-->heap-->stack
- 文本段:代码段是用来存放可执行文件的操作指令,也就是说是它是可执行程序在内存中的镜像只允许读操作,不允许写;
- 数据段: 数据段用来存放可执行文件中已初始化全局变量,换句话说就是存放程序静态分配的变量和全局变量;通过ulimit -d命令可以查看大小,一般都是unlimited
- BSS段:BSS段包含了程序中未初始化的全局变量,在内存中 bss段全部置零;
- heap: 堆,内存中用来存放动态分配的区域,分配时由低想高分配,用完后需要free;
- stack:栈用来存放局部临时变量 可以通过ulimit -s查看大小;
那么问题来了,执行代码的时候经常遇到segmentation fault,这是怎么一回事呢?请看下图,哈哈,简单吧
那么问题来了,图中其他区间很好理解,拿这里的unusable值得什么呢? 其实这里是进程的进程控制块,包含进程表示符、处理器状态信息以及进程控制信息,是不能被随便读取和写入的。
参考文献: