虚拟内存
覆盖技术
把一些不会相互调用的函数分配到相同的地址空间,当需要调用的时候覆盖内存就可以了。
需要程序员来设计,费时费力,模块的覆盖是时间换空间
交换技术
让暂时不运行的程序交换到磁盘中,当使用的时候换回内存。
只在内存不够的时候交换,磁盘的交换区的空间必须足够大,换出然后换入的时候物理内存不一定一样了,但是我们可以用虚地址解决这个问题。
虚存技术
像覆盖技术一样不把程序所有的内容都放入内存,想交换技术那样,只对进程的部分内容进行交换,
优点: 一个程序的物理空间是非连续的,更好的内存利用,允许共享代码与数据(共享库等),支持动态加载和动态链接
程序等栈段、堆段、数据段、等等分散到多个物理空间,
段号+偏移量,高位为段号,低位为偏移量,用段表来映射,段表中存了起始地址和长度信息,CPU可以在访问前做安全检测,
让段的长度固定,就成了分页机制。
物理内存被分割为大小相等的帧
dirtybit+residentbit+clockbit+页帧号
访问一个内存单元需要两次访问: 页表+数据
页表太大怎么办,多个程序多个页表,更大了,这个不能放到cpu,放到内存又会很慢
DISK中放操作系统,BIOS是基本的IO系统,检测外设,Bootloader能够加载OS,BIOS从CS段寄存器;IP指令寄存器开始执行,然后BIOS会POST(加电自检),然后BIOS找到bootloader加载Bootloader,并传递控制权,然后Bootloader找到OS,读到内存吧控制权交给OS
系统调用是应用程序主动想操作系统发出服务请求,
异常是来源于不良的应用程序的非法指令
中断是来自不同硬件设备到额计时器和网络的中断
我们不能让应用程序直接访问外设,这不安全,另外OS可以提供更好的借口,通用可移植
保存现场、查表、中断处理、清楚中断标志、恢复现场
2 / 2