- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第8章 内存
内存是内核所管理的最重要的资源之一。某进程区别于其它进程的一个特征是两个进程存在于逻辑上相互独立的内存空间(与之相反,线程共享内存)。即使进程都是同一程序的实例,比如,两个xterm或两个Emacse,内核都会为每个进程安排内存空间,使得它们看起来像是在系统之上运行的唯一进程。当一个进程不可能偶然或恶意的修改其它进程的执行空间时,系统的安全性和稳定性就会得到增强。
内核也生存在它自己的内存空间之中,即内核空间(kernel space)。与之对应的是用户空间(user space),它是所有非内核任务所处的内存空间的一个通用术语。
虚拟内存
计算机系统包括不同级别的存储器。图8-1说明了这些存储器中最重要的几项,并且以我自己原有的Linux机器(Linux box)为例标注了一些参数的估计值。当你从左向右观察该图时,会发现存储器容量越来越大而速度却越来越慢(而且每字节价格也会更低)。尤其令人注意的是,访问速度跨越了3个数量级(乘数因子为1000),而容量竟跨越了超过8个数量级(乘数因子为312500000)。(实际上有时速度的差异是可以被掩盖的,不过这些数字足以很好的说明这一部分讨论的目的。)最大的差距体现在最后两个:RAM和磁盘上,它们又分别可被称作主存和辅存。
额外附加的存储器空间总是十分诱人的,即使它们也很慢。如果在RAM被用完时,通过暂时把不用的代码和数据转移到磁盘上以腾出更多空间的方法来使用磁盘代替RAM的话,那将是很好的一件事情。正如读者可能已经知道的,Linux恰好能够做到这一点,这被称之为虚拟内存(virtual memory)。
虚拟内存是一种对RAM和磁盘(或称之为:主存和辅存)进行无缝混合访问的技术。所有这些(虚拟)内存对于应用程序来说就好像它真的存在一样。当然我们知道它并非真的内存,这正是为什么它被称为是“虚拟的”,但是多亏了内核使得应用程序无法分辨出它们的区别。对于应用程序来说,就好像真的有很大数量的RAM,只不过有时候比较慢而已。
术语“虚拟内存”还有另外一层意思,从严格意义来讲是与前述的第一种意思没有关系的。这里的虚拟内存指的是对进程驻留地址进行欺骗的方法。每个进程都会有这样一种错觉,认为它的地址是从0开始并由此连续向上发展的。很明显,这一点同时对所有进程都成立是不可能的,但是在生成代码的时候这个假定(fiction)却能够带来很大方便,这是由于进程不必知道它们是否真正从0地址开始驻留,而且它们也不必去关心此事。
这两种意思也不必相关,因为一个操作系统从理论上可以给每个进程分配一个独有的逻辑地址空间而不用混合使用主存和辅存。然而在所有我已经知道的系统中(对这两种虚拟内存的实现方式)要么都采纳要么都不采纳,这一点可能会在开始时令人感到困惑。
为了避免这种意义上的分歧,有人倾向于术语“虚拟内存”代表逻辑地址空间(logical- address-space)的意义,同时使用“分页(paging)”或“交换”表示磁盘作为内存使用(disk-as-memory)的含义。尽管这种严格的区分具有充足的理由,但是我更喜欢普通的用法。除非上下文要求,否则我很少花费精力对它们进行区分。
图8-1 具有速度和容量的存储级别
交换和分页
早期的虚拟内存(VM)系统仅能够把整个应用程序代码和数据,即完整的进程从磁盘上移出或移入磁盘。这种技术被称为交换(swapping),因为它是把一个进程同另一个进程进行了对调。出于这个原因,磁盘上为VM所保留的区域通常被称为交换空间(swap space),或简称为交换区(swap),尽管如我们所见,现代的系统已不再使用这种最初意义上的交换技术。与此类似,读者通常会见到的术语是交换设备(swap device)和交换分区(swap partition),它是磁盘分区的同义词,但是被专门作为交换空间使用,以及术语交换文件(swap file),这是一个用于交换的规则的、有固定长度的文件。
交换是很有用的,当然要比根本没有VM好的多,但是它也有一定局限性。首先,交换需要把整个进程同时调入内存,所以当运行一个需要比系统所有RAM还要大的存储空间的进程时,交换便于事无补了,即使磁盘有大量空间可供补充。
其次,交换可能会很低效。交换就必须把整个进程同时调出,这就意味着为了2K的空间你不得不把一个8MB的进程整个调出。同样的道理,即使仅仅需要执行被调进的应用程序代码的一小部分,你也必须把整个进程同时调进。
分页(paging)是把系统的内存划分成很小的块,即页面,每个页面可以独立的从磁盘调入或调出磁盘。分页与交换技术相似,但它使用更加细小的粒度(granularity)。分页比交换有更多的登记(book-keeping)开销,这是因为页面数远比进程数要多,然而通过分页可以获得更多的灵
文档评论(0)