WoW64

✍ dations ◷ 2025-12-10 19:21:38 #Windows NT,兼容层

WoW64(Windows 32-bit on Windows 64-bit)是Microsoft Windows操作系统的一个子系统,它提供在所有Windows 64位系统上运行32位应用程序的能力——这包括Windows XP Professional x64 Edition、IA-64和Windows Server 2003的64位版本,以及Windows Vista、Windows Server 2008、Windows 7、Windows 8、Windows Server 2012、Windows 8.1和Windows 10的64位版本。在Windows Server 2008 R2 Server Core中它成为了可选组件,并在Nano Server中不再提供。WoW64旨在解决32位与64位Windows中的许多差异,特别是涉及到Windows本身的结构变化。

WoW64子系统由一个轻量级兼容层组成,其在所有64位Windows版本上有类似的接口。它的目的是创建一个32位环境,为未修改的32位Windows应用程序在64位系统上运行提供一个必需的接口。在技术上,WoW64使用三个动态链接库(DLL)实现:

尽管表面上看它在所有64位Windows版本上都表现相同,但WoW64的实现取决于目标处理器架构。举例来说,面向Intel Itanium 2处理器(即IA-64架构)开发的64位Windows版本,会使用Wow64win.dll在Itanium 2的独有指令集中设置x86指令的仿真。这种仿真会比 Wow64win.dll的函数在x86-64架构(也称“Intel 64”或“AMD64”)上的计算代价更昂贵,因为当有必要执行32位线程时,处理器硬件必须从64位模式切换到兼容模式,然后再切换回64位模式。

WoW64子系统也处理其他运行32位应用程序所必需的关键问题。它参与32位应用程序与Windows组件的互动,例如注册表,64位与32位应用程序会使用不同的键。举例来说,HKEY_LOCAL_MACHINE\Software\Wow6432Node 是 HKEY_LOCAL_MACHINE\Software 的32位环境版本,并且32位应用程序不会感觉到这种重定向。有些注册表键是等效从64位映射到32位,还有些则是内容镜像,这取决于Windows的版本。

操作系统使用%SystemRoot%\system32目录放置其64位函数库和可执行文件。这样做的原因是考虑到向后兼容性,许多旧款程序采用硬编码使用该路径。当执行32位应用程序时,WoW64会将32位透明重定向到 %SystemRoot%\SysWoW64,那里放着32位函数库和可执行文件。32位应用程序不会知道自己在64位操作系统上运行。32位应用程序可以通过伪目录%SystemRoot%\sysnative访问真实的存有64位函数库和可执行文件的文件夹%SystemRoot%\System32

你会看到有两个Program Files目录可见,里面分别放着32位和64位应用程序。存储32位文件的目录名为 Program Files (x86) 以区分两者,而64位目录使用原有的 Program Files 为名,不附加任何限定名称。

只包含32位内核模式驱动程序,或者插入组件到仅64位实现的组件进程(例如Windows Explorer)的内存空间的32位应用程序不能在64位平台上执行。32位服务程序是支持的。SysWOW64文件夹位于操作系统所在分区的Windows文件夹,其包含许多支持32位应用程序的程序(例如cmd.exe、odbcad32.exe,为32位应用程序注册ODBC连接等)。面向MS-DOS和Windows早期版本的16位应用程序通常不兼容64位版本的Windows Vista、7和8,但可以通过Windows Virtual PC或DOSBox运行在16位或32位的Windows操作系统上。32位版本的Windows XP、Vista、7和8在另一方面通常也可以几乎无问题地运行16位应用程序。16位应用程序不能直接运行在x64版本的Windows上,因为CPU在x64模式下运行时不支持VM86。

Internet Explorer实现了32位与64位两个应用程序版本,因为互联网上有许多32位ActiveX组件,而它们不可能在64位版本上运行。Internet Explorer的32位版本被定为默认版本,并且64位版本不能被设置为默认浏览器。

WoW64 64位版本中透明层的一个程序错误导致所有依赖Windows API函数GetThreadContext的32位应用程序不兼容。此类应用包括应用程序调试器、调用堆栈跟踪器(例如IDE显示调用堆栈)和使用垃圾收集(GC)引擎的应用程序。受影响最广泛的一个GC引擎是Boehm GC,它被同样流行的Mono作为默认的垃圾收集引擎。虽然Mono截至2010年10月有一种新的、可选的GC(称作SGen-GC),但它与Boehm GC执行堆栈扫描的方式相同,因此它也不兼容WoW64。截至2010年11月15日,微软没有提供修复计划或变通解决方案。

据微软介绍,运行在WOW64下的32位软件与在32位Windows上的执行性能相近,但可能增加少许线程和其他开销。

一个32位应用程序在64位系统上可以完全使用4GB虚拟内存,而在32位系统上,部分可寻址内存无法使用,因为那会被内核和内存映射的外部设备(如显卡)使用。

相关

  • 肾上腺素肾上腺素(Epinephrine或Adrenaline), 3,4-三羟基-N-甲基苯乙胺。是肾上腺髓质分泌的激素及神经传导物质,也是一种药物。肾上腺素被应用于治疗多项疾病,包含全身性过敏反应、心搏
  • 黄酮类化合物黄酮类化合物(英语:Flavonoid,又称类黄酮)基于2-苯基色原酮-4-酮(2-苯基-1-苯并吡喃(英语:Benzopyran)-4-酮)骨架的黄酮类化合物,如右图所示,基本母核为2-苯基色原酮类化合物,现在则泛指
  • 色立体色立体是一种三维表示的色彩空间,类似于二维表示的色环。色立体额外增加的维度使得它可以额外多表现一个维度的色彩变化。二维色轮通常表现色相的变化(红,绿,蓝等)和明度(明暗层次
  • 黑非洲撒哈拉以南非洲(英语:Sub-Saharan Africa),指撒哈拉沙漠以南的非洲地区,又称亚撒哈拉地区、下撒哈拉、漠南非洲,也有称黑非洲(Negro Africa)。政治上,包括了所有或部分领土位于撒哈拉
  • 章学诚《清代学者象传》之章学诚像章学诚(1738年-1801年),清代史学家、思想家。字实斋,号少岩,浙江会稽(今浙江绍兴)人 。父章镳是乾隆七年(1742年)进士,官湖北应城知县。学诚幼资椎鲁,体弱多
  • 硫酸镝硫酸镝是一种无机化合物,化学式为Dy2(SO4)3。用硫酸溶解氧化镝,可以得到硫酸镝。
  • 特写特写是指在电影、电视或摄影中以非常近的距离拍摄人或物体。特写镜头和中镜头、长镜头一起构成了标准的拍摄手法。特写能够展现细节,得到强烈清晰的视觉效果,但却不能获得宽阔
  • 潜江站潜江站,位于中华人民共和国湖北省潜江市杨市街道,是汉宜铁路上的高铁站,建于2012年,由武汉铁路局管辖。
  • Ho-103重机枪Ho-103重机枪(日语:ホ103 一式十二・七粍固定機関砲;假名:ホ一〇三 いっしきじゅうにぃてんななみりこていきかんほう),是第二次世界大战期间大日本帝国陆军的航空机关枪。1930年
  • 海豹猎捕海豹猎捕(英语:Seal hunting 或 Sealing;法语:Chasse aux phoques;因纽特语:Nattirhiurtuq)是指人类出于生活需求或商业利益而猎捕海豹(true seals)与海狗(fur seals)的行为。现今的猎