一,进程内存空间
进程的组成部分:代码段,数据段,堆,栈,程序计数器
其中代码段存放代码,数据段存放静态变量和全局变量,堆存放运行时的一些数据,栈则存放局部变量,这个跟JVM的内存模型很像,方法区(代码段和数据段),堆,虚拟机栈,本地方法栈,程序计数器
命令:cat /proc/${pid}/status /proc/${pid}/maps
可以查看进程的状态和映射情况
二,内存管理
通过三级高速缓存来提高效率,利用局部性原理加载cache
用户进程不可以访问操作系统的内存数据,用户进程之间不能互相影响,这是通过硬件实现的,通过CPU的基址寄存器和限长寄存器来实现,操作系统一般不干预CPU对内存的访问
程序从逻辑地址转换为物理地址的时机:
程序加载流程:编译->链接(链接三方库)->加载(加载系统库0)->内存代码 ,转换发生在运行时由MMU完成
如果在编译时期或者是加载时期转换,则不允许移动,有很大的限制性,不现实