WoW64

✍ dations ◷ 2025-08-02 21:11:24 #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位系统上,部分可寻址内存无法使用,因为那会被内核和内存映射的外部设备(如显卡)使用。

相关

  • 厕刷厕刷是一种可以用来清洗厕所的刷子,通常置于厕所的便器旁,一般来说会搭配厕所清洁剂或漂白剂来使用。不过,厕刷既不能用来清洗存水弯(因为构不到)也不能用来清洗马桶座圈。最早制
  • 鲁道夫·菲尔绍鲁道夫·路德维希·卡尔·菲尔绍(德语:Rudolf Ludwig Karl Virchow (发音 或 ),1821年10月13日-1902年9月5日),又译魏尔肖、维尔肖、魏修,德国医生、人类学家、病理学家、史前学家
  • 圣公会历列表坎特伯雷大主教 (贾斯汀·韦尔比) 普世圣公宗主教长会议 兰柏会议 普世圣公宗咨议会 主教/教区 主教制 基督教 · 基督教教会 (耶稣 · 基督 · 圣保罗) 圣公宗(历史) 圣公
  • 夜鹦鹉夜鹦鹉(学名:),又名夜行鹦鹉,是澳洲特有的一种细小鹦鹉。它们原先是分类在独自的属中(),但很多学者都将它们连同地栖鹦鹉分类在之中。虎皮鹦鹉亦是它们的远亲。于1912年至1979年没有
  • 斐波那契回调斐波那契回调(Fibonacci retracement)是一种技术分析方法,用于判断支持和阻力位,得名于斐波那契数列。斐波那契回调所根据的理论是,当价格向一个方向变动,其向相反方向的回调会在
  • 毒液2《毒液2》(英语:)是一部预计于2021年上映的美国超级英雄电影,由漫威漫画旗下角色毒液故事改编,哥伦比亚影业制作,并由索尼影视娱乐发行。本片为“索尼影业漫威角色宇宙”的第三部
  • 安德雷·马尔可夫安德雷·安德耶维齐·马尔可夫(俄语:Андре́й Андре́евич Ма́рков,英语:Andrey Andreyevich Markov,1856-1922)是一位俄国数学家。他在随机过程领域做出重
  • GNU C库GNU C库(英语:GNU C Library,常简称为glibc)是一种按照LGPL许可协议发布的,自由的,公开源代码的,方便从网络下载的C的编译程序。GNU C运行期库,是一种C函数库,是程序运行时使用到的一
  • 亦歌亦歌是一个2007年上线的中国在线音乐试听服务网站,网站由北京新乐时代持有。除了在线播放器,亦歌还支持PC、Mac及Android手机的等平台,此外也提供了多种插件。播放器默认采用自
  • 鹿港粉碎洗涤盐工厂鹿港粉碎洗涤盐工厂是台湾日治时期由总督府专卖局在昭和十一年(1936年)5月兴建的精盐厂,位在今彰化县鹿港镇一带,预定年产量是5000公吨(1940年与1941年的实际产量是4250公吨与750