Raymond Chen 2008年12月22日
在64位Windows上,32位程序在仿真层上运行,如果你不喜欢那样,那就不要使用仿真器.
在64位Windows上,32位程序在一个仿真层上运行。这个仿真层模拟了x86架构,虚拟化了CPU、文件系统、注册表、环境变量、系统信息函数等所有这些东西。如果一个32位程序尝试查看系统,它将看到一个32位的系统。例如,如果程序调用`GetSystemInfo`函数来查看正在运行的处理器,它会被告知它正在一个32位处理器上运行,拥有32位的地址空间,在有一个32位天空和32位树木中32位鸟儿的世界里。
仿真的目的就是通过模拟一个32位的执行环境来让32位程序感到满意。
评论者Koro正在编写一个32位程序形式的安装程序,它检测到自己正在64位系统上运行,并且想要将文件(可能还包括设置注册表项和执行其他安装任务)复制到64位目录中,但仿真层将这些操作重定向到了32位位置。问题是“从32位应用程序中找到x64程序文件目录的方法是什么?”
答案是“与系统合作比与它对抗更好。”如果你是一个32位程序,那么每次你尝试与外界交互时,你都会与仿真器作斗争。相反,只需将你的安装程序重新编译为64位程序。让32位安装程序检测它是否正在64位系统上运行,并启动64位安装程序。64位安装程序不会在32位仿真层上运行,所以当它尝试复制文件或更新注册表键时,它将看到真实的64位文件系统和真实的64位注册表。
标签:仿真,...,Old,32,程序,64,注册表,安装程序,bit From: https://blog.csdn.net/weixin_41863029/article/details/139551888