打印本文 打印本文 关闭窗口 关闭窗口
深入SQL SERVER 2000的内存管理机制(一)
作者:武汉SEO闵涛  文章来源:敏韬网  点击数4615  更新时间:2007/11/14 11:03:38  文章录入:mintao  责任编辑:mintao
使用虚拟内存(而不是堆的方式),大部分的内存分配的代码分解到最后都是调有Win32VirtualAllo VirtualFree API函数。SQL SERVER通过调用VirtualAllo函数来预留和提交虚拟内存,通过VirtualFree函数来释放内存。

 

虚拟内存和物理内存

X86处理器的系列中,Windows提供所有的程序可以寻址4GB虚拟内存空间。所谓“虚拟”的意思是,这并不是传统意义上的内存,它仅仅是一段没有物理存储的隐式地址段。因为只有一个程序开始内存分配,才开始使用这些地址段和物理的分配存储空间。而且,这些物理的存储空间并不需要物理的内存(不完全),通常是磁盘空间。明确的说应该是在系统的虚拟页文件中。这就是为什么有许多程序(每个程序有4GB的虚拟内存空间)可以同时运行在只有128M的物理内存的机器上,就像每个程序自己分配真实的内存一样。Windows透明地控制从系统页文件拷贝和读取数据,因此程序可以在运行的机器上分配比物理内存更多的内存空间并且各种程序可以均等的访问该机器物理内存。

4GB的内存地址空间分为2块:用户内存空间和核心内存空间。默认每个容量为2G,你可以通过Windows NT 系列操作系统的BOOT.INI文件来改变默认空间的大小(比如:Windows NT,Windows 2000,Windows XP Windows Server 2003都是Windows NT 系列的产品,Windows 9x Windows ME不是的)。

上一页  [1] [2] [3] [4] [5]  下一页

打印本文 打印本文 关闭窗口 关闭窗口