描述 Windows 操作系统内存管理的方法

来源:互联网 发布:ubuntu关闭x server 编辑:程序博客网 时间:2024/04/28 23:20

 

(1)有三种方法:虚拟内存,内存映射文件,内存堆栈。

虚拟内存是将页文件加载到内存,适用于比较大的对象或结构;

内存映射文件是将磁盘上文件加载到内存,适用于大文件和单机的进程间内存共享;

堆栈就是动态的分配内存,适用于小对象的创建。

这些在windows核心编程中都描述得很详细的。

(2)当进程要读自己的虚拟地址空间中的数据时:

 

if(数据在物理内存中)   {   虚拟地址转换成物理地址   读数据   }   else   {   if(数据在磁盘中)    {     if(物理内存还有空闲)     {      把数据从磁盘中读到物理内存      虚拟地址转换成物理地址      读数据     }     else     {       把物理内存中某页的数据存入磁盘       把要读的数据从磁盘读到该页的物理内存中       虚拟地址转换成物理地址       读数据     }    }    else    {    报错    }   }

(3)当程序运行时需要从内存中读出这段程序的代码。

代码的位置必须在物理内存中才能被运行,由于现在的操作系统中有非常多的程序运行着,内存中不能够完全放下,所以引出了虚拟内存的概念。把哪些不常用的程序片断就放入虚拟内存,当需要用到它的时候在load入主存(物理内存)中。这个就是内存管理所要做的事。内存管理还有另外一件事需要做:计算程序片段在主存中的物理位置,以便CPU调度。

内存管理有块式管理,页式管理,锻式和锻页式管理。现在常用事锻页式管理 块式管理:把主存分为一大块、一大块的,当所需的程序片断不在主存时就分配一块主存空间,把程 序片断load入主存,就算所需的程序片度只有几个字节也只能把这一块分配给它。这样会造成很大的浪费,平均浪费了50%的内存空间,但时易于管理。

页式管理:把主存分为一页一页的,每一页的空间要比一块一块的空间小很多,显然这种方法的空间利用率要比块式管理高很多。

段式管理:把主存分为一段一段的,每一段的空间又要比一页一页的空间小很多,这种方法在空间利用率上又比页式管理高很多,但是也有另外一个缺点。一个程序片断可能会被分为几十段,这样很多时间就会被浪费在计算每一段的物理地址上(计算机最耗时间的大家都知道是I/O吧)。

锻页式管理:结合了段式管理和页式管理的优点。把主存分为若干页,每一页又分为若干段。好处就很明显,不用我多说了吧。

各种内存管理都有它自己的方法来计算出程序片断在主存中的物理地址,其实都很相似。

原创粉丝点击