当阅读一些开源服务器源码的时候, 如果不知道以下知识, 就会有知识盲点, 导致不知所云.
这篇博客会讲述一些相关的编程知识点, 把之前的笔记总结一下.
还是那句老话, 带着问题阅读是最容易让人类迅速进入状态的.
进程的内存布局是什么样的?
记忆口诀 : 文初堆栈
每个进程所分配的内存由很多部分组成,通常称之为“段( segment)”。如下所示。
- 文本段
包含了进程运行的程序机器语言指令。文本段具有只读属性,以防止进程通过错
误指针意外修改自身指令。因为多个进程可同时运行同一程序,所以又将文本段设为可
共享,这样,一份程序代码的拷贝可以映射到所有这些进程的虚拟地址空间中。 - 初始化数据段
包含显式初始化的全局变量和静态变量。当程序加载到内存时,从可执
行文件中读取这些变量的值。 - 未初始化数据段
包含了未进行显式初始化的全局变量和静态变量。程序启动之前,系统
将本段内所有内存初始化为0。出于历史原因,此段常被称为BSS段,这源于老版本的
汇编语言助记符“block started by symbol”o将经过初始化的全局变量和静态变量与未经
初始化的全局变量和静态变量分开存放,其主要原因在于程序在磁盘上存储时,没有必
要为未经初始化的变量分配存储空间。相反,可执行文件只需记录未初始化数据段的位
置及所需大小,直到运行时再由程序加载器来分配这一空间。 - 堆(heap)
是可在运行时(为变量)动态进行内存分配的一块区域盛顶端称作program break。 - 栈( stack)
是一个动态增长和收缩的段,由栈帧(stack frames)组成。系统会为每个
当前调用的函数分配一个栈帧。栈帧中存倍了函数的局部变量(所谓自动变量)、实
参和返回值。
线程的同步机制有哪些?
- 互斥量
- 条件变量
- 自旋锁
自旋锤与互斥量类似,但它不是通过休眠使进程阻塞,而是在获取镪之前一直处于忙等(自
旋)阻塞状态.自旋锁可用于“下情况锁被持有的时间短,而且线程并不希望在重新调度上花
费太多的成本。 - 读写锁(也叫做共享互斥锁)
读写锁也叫做共享互斥锁( shared-exclusive lock)。当读写锁是读模式锁住时,就可以说成是
以共享模式锁住的。当它是写模式锁住的时候,就可以说成是以互斥模式锁住的。
. . .