【精品】linux内存管理.doc

【精品】linux内存管理.doc

ID:49196401

大小:280.00 KB

页数:14页

时间:2020-03-01

【精品】linux内存管理.doc_第1页
【精品】linux内存管理.doc_第2页
【精品】linux内存管理.doc_第3页
【精品】linux内存管理.doc_第4页
【精品】linux内存管理.doc_第5页
资源描述:

《【精品】linux内存管理.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、摘要:本章首先以应用程序开发者的角度审视Linux的进程内存管理,在此基础上逐步深入到内核中讨论系统物理内存管理和内核内存的使用方法。力求从外到内、水到渠成地引导网友分析Linux的内存管理与使用。在本章最后,我们给出一个内存映射的实例,帮助网友们理解内核内存管理与用户内存管理之间的关系,希望大家最终能驾驭Linux内存管理°刖旨内存管理一向是所有操作系统书籍不惜笔墨重点讨论的内容,无论市面上或是网上都充斥着大量涉及内存管理的教材和资料。因此,我们这里所耍写的Linux内存管理采収避重就轻的策略,从理论层面就不去班门弄斧,贻笑大方了

2、。我们最想做的和可能做到的是从开发者的角度谈谈对内存管理的理解,最终目的是把我们在内核开发中使用内存的经验和对Linux内存管理的认识与大家共享。当然,这英中我们也会涉及到一些诸如段页等内存管理的基本理论,但我们的目的不是为了强调理论,而是为了指导理解开发中的实践,所以仅仅点到为止,不做深究。遵循“理论來源于实践”的“教条”,我们先不必一下子就钻入内核里去看系统内存到底是如何管理,那样往往会让你陷入似懂非懂的窘境(我当年就犯了这个错误!)。所以报好的方式是先从外部(用八编程范畴)來观察进程如何使用内存,等到大家对内存的使用有了较直观

3、的认识后,再深入到内核屮去学习内存如何被管理等理论知识。垠后再通过一个实例编程将所讲内容融会贯通。进程与内存进程如何使用内存?毫无疑问,所有进程(执行的程序)都必须占用一定数量的内存,它或是用来存放从磁盘载入的程序代码,或是存放収自用户输入的数据等等°不过进程对这些内存的管理方式因内存用途不一而不尽相同,有些内存是事先静态分配和统一冋收的,而有些却是按需要动态分配和回收的。对任何一个普通进程來讲,它都会涉及到5种不同的数据段。稍有编程知识的朋友都能想到这几个数据段中包含有’'程序代码段”、“程序数据段”、’‘程序堆栈段”等。不错,这

4、几种数据段都在其屮,但除了以上几种数据段Z外,进程还另外包含两种数据段。下面我们来简单归纳一下进程对应的内存空间中所包含的5种不同的数据区。代码段:代码段是用来存放可执行文件的操作指令,也就是说是它是可执行程序在内存屮的镜像。代码段需要防止在运行时被非法修改,所以只准许读取操作,而不允许写入(修改)操作一一它是不可写的。数据段;数据段用來存放可执行文件中己初始化全局变量,换句话说就是存放程序静态分配I的变量和全局变量。BSS段叫BSS段包含了程序中未初始化的全局变量,在内存中bss段全部置零。11,1静态分配内存就是编译器在编译程序

5、的时候根据源程序來分配内存.动态分配内存就是在程序编译之后,运行时调用运行时刻库函数來分配内存的.静态分配山于是在程序运行之前,所以速度快,效率高,但是局限性大.动态分配在程序运行时执行,所以速度慢,但灵活性高.2⑵术语“BSSP经有些年头了,它Hiblockstartedbysymbo/的缩写。因为未初始化的变最没有对应的值,所以并不需要存储在可执行对象屮。但是因为C标准强制规定未初始化的全局变最要被赋予特殊的默认值(基木上是0值),所以内核要从可执行代码装入变量(未赋值的)到内存中,然后将零页映射到该片内存上,于堆(heap):

6、堆是用于存放进程运行中被动态分配的内存段,它的大小并不固定,可动态扩张或缩减。当进程调用malloc筹函数分配内存时,新分配的内存就被动态添加到堆上(堆被扩张);当利用fee等函数释放内存时,被释放的内存从堆中被剔除(堆被缩减)栈••栈是用户存放程序临时创建的局部变量,也就是说我们函数括弧“{}”中定义的变量(但不包括static声明的变量,static意味看在数据段中存放变量)。除此以外,在函数被调用吋,其参数也会被压入发起调用的进程栈中,并II待到调用结束后,函数的返冋值也会被存放冋栈屮。山于栈的先进先出特点,所以栈特别方便用来

7、保存/恢复调用现场。从这个意义上讲,我们可以把堆栈看成一个寄存、交换临时数据的内存区。进程如何组织这些区域?上述儿种内存区域中数据段、BSS和堆通常是被连续存储的——内存位置上是连续的,而代码段和栈往往会被独立存放。有趣的是,堆和栈两个区域关系很“暧昧”,他们一个向下“长”(i386体系结构中栈向下、堆向上),一个向上“长”,相对而生。但你不必担心他们会碰头,因为他们Z间间隔很大(到底大到多少,你可以从下而的例子程序计算一下),绝少有机会能碰到一•起。下图简要描述了进程内存区域的分布:代码段“事实胜于雄辩”,我们用一个小例子(原形取

8、白《User-LevelMemoryManagement^)来展示上面所讲的各种内存区的差别与位置。^include^include是这些未初始化变最就被赋予了0值。这样做避免了在H标文件中进行显

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。