文章目录
进程地址空间
三个问题:
什么是进程地址空间?
为什么要有地址空间?
地址空间是怎么做的?
进程地址空间:
页表:
在创建父进程的时候,通过查询页表,将进程在进程地址空间里面开辟的变量所对应的虚拟地址转换为物理内存上的物理地址。
在创建子进程的时候,一开始默认的是子进程指向的和父进程一样的页表,进程在进程地址空间里面开辟的变量所对应的虚拟地址也和父进程一样,所以父子进程代码可以共享。
当父进程的g_val=100
,子进程的g_val=200
时,他们的虚拟地址是一样的,然后子进程顺着页表找到虚拟地址对应的物理地址,结果发现这个进程的变量是和父进程共享的,所以操作系统会在写入之前,重新划分一段空间,然后把父进程的g_val=100
的值拿到新的空间内(这个也叫写时拷贝,是操作系统自动完成的),然后把子进程的g_val=200
再拿到这个物理空间里,把原来的100
给覆盖掉。
这段空间的物理地址肯定也和之前父进程的物理地址空间不一样了。至此就将父子进程的同一个变量的不同值在物理层面上分开了。
输入权限指的是rwx
这种的权限。
标志位:对应的代码和数据是否已经被加载到内存中。
如果变量根据虚拟地址找物理地址的时候发现标志位显示对应的代码和数据没有被加载到内存就会触发缺页中断
。写时拷贝也是缺页中断。
谈一下细节:
地址空间到底是什么?
在32位计算机中,有32位地址和数据总线 ---> 每一根总线
每一根地址总线只有0,1两种情况,32根就是2^32^种情况。
2^32^*1byte = 4GB
地址总线排列组合形成的地址范围[0,2^32^)
所谓的进程地址空间,本质上是一个描述进程可视范围的大小,进程空间内一定要存在各种区域划分,对线性地址进行
start
和end
即可。地址空间本质上是内核的一个数据结构对象,类似PCB一样,地址空间也是要被操作系统管理的:先描述,再组织。
所以,什么叫做进程?以及进程地址空间,为什么?
我们先讲个故事:
一个富翁有100w,但是他有好几个私生子,这些私生子互相不认识,但都知道富翁有100w。他们都认为自己以后能得到100w的遗产。
我们可以把富翁当作操作系统,私生子当作进程,100w当作进程地址空间。
虚拟地址空间存在的意义?
增加进程虚拟空间,可以让我们访问内存的时候,增加一个转换的过程,在这个转化的过程中,可以对我们的寻址请求进行审查,所以一旦异常访问,直接拦截,该请求就不会到达物理内存,保护物理内存。
进程是可以被挂起的,但是你又怎么知道你的进程的代码数据,在不在内存里面呢?
进程在被创建的过程种,先创建内核数据,然后加载对应的可执行程序。