深入SQLServer 2000的内存管理机制(二)
可访问大地址的应用 (Large-Address-Aware Executables)
dedecms.com
在Windows增加支持/3GB参数以前,一个应用程序是无法访问一个带有高位设置的指针.一个32位的指针只有前31位地址空间可以被用户模式的应用程序访问.这剩余的一位不用.因此有一些聪明的开发者因为其他的目的不愿意在处理内存地址空间时浪费这一位.(举例来说:可以用来标志一个指针引用其它应用程序分配的数据类型).这样就/3GB参数就碰到一个难题,因为这种类型的程序不能方便的区分一个合法的指针引用的内存空间在2G的分界线以上与一个内存地址空间在2G以下,但它的高位已经被用做它用的指针.基本上假如一台机器用/3GB的参数启动,这种应用程序是无法运行的.为解决这种状况,微软在WIN32的PE文件Characteristics字段增加了一个新的标志位来表示一个程序是否运行在可访问大地址的(Large-Address-Aware Executables)模式.当该标志位被起用( IMAGE_FILE_LARGE_ADDRESS_AWARE ),该可执行文件头部Characteristics字段的32位被置位.通过这个可执行文件头部的标志位,应用程序可以暗示WINDOWS 它可以处理带有高位设置的指针,这样就不会带来任何异常结果.当该标志被置位并且支持这种方式启动的Windows也是通过/3GB的参数启动,这时操作系统会提供一直扩展的私有用户模式的地址空间给应用程序.你可以通过工具,比如: DumpBin 和 ImageCfg (转储可执行文件的头部)来检查一个可执行文件的该标志位.Visual C 通过 /LARGEADDRESSAWARE 连接器开关来表示IMAGE_FILE_LARGE_ADDRESS_AWARE,SQL SERVR已经将该标志位激活,所以你可以在支持/3GB参数的Windows 版本中使用该参数,这样操作系统回自动扩展SQL SERVER的用户内存空间. 本文来自织梦
注释:Windows在可执行文件启动时检查IMAGE_FILE_LARGE_ADDRESS_AWARE 标志位,但忽略DLL文件.DLL代码必须自动处理高位被置位的指针。 本文来自织梦
物理内存扩展 本文来自织梦
Intel 处理器自从Pentium PRO开始,以后的处理器都支持一种物理内存扩展(PAE)的内存映射模式。PAE模式提供了可以访问64GB的物理内存空间。在PAE模式中,内存治理单元(Memory Management Unit (MMU))仍然执行:页目录入口page directory entries(PDEs) 和页表入口page table entries (PTEs),但是在此之上有一个新的级别:页目录指针表。同时,在PAE模式PDEs 和PTEs是64位的(不仅仅是标准的32位),这样系统可以映射比标准转换更多的内存空间,因为PDEs 和PTEs模式的寻址宽度是标准的2倍。这并不仅仅是增加了页目录指针表。页目录指针表被用来治理这些大容量表和索引。一些非凡版本的Windows内核需要运行在PAE模式。这中内核集成在Windows 2000以及以后的版本中,在单处理器的机器中体现在Ntkrnlpa.exe文件中,在多处理器的机器中体现在Ntkrnlpamp.exe文件中。你可以向增加/3GB和/USERVA参数一样在BOOT.INI文件中加/PAE参数激活PAE模式。
地址窗口扩展 dedecms.com
Windows的地址窗口扩展(AWE)机制可以答应应用程序访问超过4GB的物理内存。一个32位的指针是一个整数,只能保存0x00000000到0xFFFFFFFF的值,就是说可以引用4GB 以内线性的内存地址空间,AWE答应一个应用程序绕过这些限制,通过操作系统访问所有的内存空间。
文章评论
共有位Admini5网友发表了评论 查看完整内容