虚拟地址空间详解
虚拟地址空间
1.物理内存缺乏访问控制,安全性不足,各个进程访问如果都访问物理内存,可能相互影响,影响了进程的独立性,物理内存极小,并发所需内存大,容易导致内存不足,还容易导致内存碎片化的问题
2.我们平时在编译器对内存进行的操作都是对虚拟内存的操作。
3.虚拟内存和物理内存通过页表建立映射关系,操作系统控制页表选择性地映射,从而阻止非法访问。
4.内核数据结构中的mm_struct通过对内存空间区域的划分组织了虚拟地址空间,进程pcb中存贮了指向mm_struct的指针。
5.在使用编译器编译程序的时候,程序内部已经有地址了,程序被加载到物理内存时,物理内存中的程序仍然存有虚拟地址,再利用这个虚拟地址对虚拟地址空间进行初始化,再通过页表建立映射关系(为什么能建立?原因是虚拟内存和物理内存都存了一样的虚拟地址!),假如cpu读取的是跳跃指令,它通过页表找到这条指令的物理内存,通过读取这个数据本身存储的虚拟地址数据,再次在虚拟地址找到下一条指令,又因为编址方式相同,它就能在虚拟内存中找到下一行要执行的指令,从而实现cpu在不知道物理地址的情况下完成指令的执行,cpu甚至完全接触不到内存的物理地址。
6.缺页中断技术是指:在虚拟地址空间上申请的内存,实际的物理内存可能并没有给你分配空间,而是当你访问/写入物理内存时,才申请物理空间,构建页表映射,从而访问物理内存。程序被加载至物理内存运行的时候,会建立虚拟地址空间,并不会分配实际的物理内存,而当进程需要访问资源的时候才会由内核的请求分页机制产生缺页中断,这时才会将需要访问的资源从磁盘加载至物理内存,并且建立虚拟地址和物理地址的映射,调入物理内存页,更新页表,通过这种方式保证我们的物理内存只有在实际使用的时候才进行分配,避免了内存浪费。CPU拿到虚拟内存的地址之后,通过MMU内存管理单元进行映射至其对应的物理内存,从而访问资源。
7.虚拟内存的好处有:和物理内存实现解耦合,让操作系统更好地管理资源,通过缺页中断技术更好地分配资源,同时虚拟内存内数据有序,而物理内存中数据是乱序的,有序更方便对数据的访问。
8.物理内存中的代码和数据来自磁盘。
9.虚拟内存技术可以实现很多进程的同时分批加载,分批换出(当进程短时间不会被执行时换成到磁盘,节省内存空间)。
10.每一个进程的页表映射在不同的物理内存上,保证了进程的独立性,父子进程映射在同一款物理内存上,但因为有了写时拷贝技术使得一方想要修改物理内存时它的页表就会指向一块新的区域,写入改变后的新值。
名词解释:
虚拟内存是一种技术
mm_struct这个内核数据结构所描述了虚拟地址空间
虚拟地址是mm_struct中划分的一块地址