第5章 操作系统的内存管理
长期以来内存是重要的计算机资源。在内存有限的情况下,虚拟内存的技术就引入了。
~window内存管理 ~
win32为每一个win32进程提供了私有且基于页的4GB(32位)大小的线性虚拟地址空间
2进程工作集
频繁的调页操作会引起磁盘i/o,会大大的降低程序的运行效率对于每一个进程,虚拟内存管理器都会将其一定的内存驻留在内存里,并跟踪性能指标。工作集会动态变化的,如果所执行的代码不再工作集中,则会引起额外的磁盘i/o,所以在虚拟内存调页时不仅仅调入需要的页,同时将附近的页页调入其中
3windows相关的api
在win32下,开发人员可以使用以下的5组函数
(1)传统的CRT函数(malloc/free)这组函数平台无关,可以移植到非win下
(2)global heap/local heap函数,global heap为系统所有进程共有的堆,local heap为每个进程私有的堆。不推荐使用。
(3)虚拟内存函数(virtualalloc/virtualfree)这组函数通过保留和提交虚拟内存的空间地址来操作内存。
(4)内存映射文件函数,系统使用内存映射文件函数来加载exe和ddl
(5)堆内存函数win32平台中每个堆都是各自进程私有的,每个进程除了默认的进程堆,还可以创建自己的进程堆
~linux~内存管理机制
1内存布局
-------------
内核 1gb
-------------
栈
-----
-----
堆
-----
bss
--
data
-----
code
------------
2物理内存管理
使用的是兄弟堆算法
与每个内存区域都有兄弟区域,当两个区域都收回时,合并成一个更大的区域,当有内存请求时找内存大小相适应的区域,否则对一块大的区域进行划分,直到找到合适大小的区域、
3虚拟内存管理
用来维护虚拟地址空间的数据结构是vm_area_struct,当vm_area_struct不超过32个时,vm_area_struct被连成一个链表,当超过32个时,这些vm_area_struct被组织成为平衡二叉树。目的是提高查询速率