当前位置:首页 > c++ > 为什么64位windows上访问系统目录时64位程序转到System32,而32位程序转到了SysWOW64?

为什么64位windows上访问系统目录时64位程序转到System32,而32位程序转到了SysWOW64?

xuwenyan1个月前 (07-13)c++1830

我们通常使用SHGetKnownFolderPathGetSystemDirectory来获取System目录,这里使用GetSystemDirectory演示。

我们会发现GetSystemDirectory无论是32位程序调用还是64位程序调用,所得到的目录都是C:WindowsSystem32

 

 

这看起来32位程序和64位程序访问系统目录并没有什么区别,但是当需要操作文件时就会不同了,我们在系统目录创建一个文件演示一下(注意操作系统需要管理员权限)

 

 

我们可以看到32位程序和64位程序同样在系统目录创建test.text文件,但最终所处的目录是不同的,这是因为windows文件重定向器把32位程序重定向到了SysWOW64目录,关于windows文件重定向器详情参考微软文档:文件系统重定向器

概述文件系统重定向器

%windir%System32 目录是为 64 位 Windows 上的 64 位应用程序保留的,而32位程序就会被重定向到%windir%SysWOW64,为了兼容性,应用程序不应直接使用路径。相反,应该调用API获取路径。

原始路径32 位 x86 进程的重定向路径32 位 ARM 进程的重定向路径
%windir%System32%windir%SysWOW64%windir%SysArm32
%windir%lastgoodsystem32%windir%lastgoodSysWOW64%windir%lastgoodSysArm32
%windir% egedit.exe%windir%SysWOW64 egedit.exe%windir%SysArm32 egedit.exe

如何禁用文件重定向

应用程序可以使用Wow64DisableWow64FsRedirectionWow64RevertWow64FsRedirection函数来控制 WOW64 文件系统重定向器。禁用文件系统重定向会影响调用线程执行的所有文件操作,因此只有在需要单个CreateFile调用时才应禁用它,并在函数返回后立即重新启用它。长时间禁用文件系统重定向会阻止 32 位应用程序加载系统 DLL,从而导致应用程序失败。

 

文件系统重定向器避坑

如果执行进程导致系统显示 UAC 提示,则不会发生重定向。而是启动所请求文件的 64 位版本。为防止出现此问题,请指定 SysWOW64 目录以避免重定向并确保访问该文件的 32 位版本,或者以管理员权限运行 32 位应用程序,以便不显示 UAC 提示。关于如何获取SysWOW64 目录,请使用GetSystemWow64DirectorySHGetKnownFolderPath

某些子目录免于重定向。对这些子目录的访问不会重定向到 %windir%SysWOW64:%windir%system32catroot
%windir%system32catroot2
%windir%system32driverstore
%windir%system32driversetc
%windir%system32logfiles
%windir%system32spool

    文章作者:xuwenyan
    版权声明:本文为本站原创文章,转载请注明出处,非常感谢,如版权漏申明或您觉得任何有异议的地方欢迎与本站取得联系。

    相关文章

    C++ 获取进程所在目录(进程全路径)

    C++ 获取进程所在目录(进程全路径)

    打开windows任务管理器,会看到很多的进程在运行,随机挑选一个,如何通过c++代码获取某一个进程的所在全路径呢?这也是在windows软件开发中经常遇到的需求。通过进程名获取进程全路径由于可能很多...

    排序算法-快速排序

    排序算法-快速排序

    排序算法的思想非常简单,在待排序的数列中,我们首先要找一个数字作为基准数(这只是个专用名词)。为了方便,我们一般选择第 1 个数字作为基准数(其实选择第几个并没有关系)。接下来我们需要把这个待排序的数...

    排序算法-冒泡排序

    排序算法-冒泡排序

    冒泡排序也是一种简单直观的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法...

    排序算法-选择排序

    排序算法-选择排序

    选择排序是一种简单直观的排序算法,无论什么数据进去都是 O(n²) 的时间复杂度。所以用到它的时候,数据规模越小越好。唯一的好处可能就是不占用额外的内存空间了吧。时间复杂度O(n²)最坏情况合适发生?...

    大端模式和小端模式的区别以及如何判断大小端

    大端模式和小端模式的区别以及如何判断大小端

    在计算中,字节顺序是指数字的二进制表示内的字节(或有时是位)的顺序。它也可以更普遍地用于指代任何表示的内部排序,例如数字系统中的数字或日期的部分。在最常见的用法中,字节顺序表示多字节数字内的字节顺序,...

    c++时间戳转年月日时分秒

    c++时间戳转年月日时分秒

    时间戳转年月日时分秒是比较常用的功能,调用api localtime_s把时间戳转成tm结构体,就可以通过tm结构体中的成员得到对应的年月日时分秒,需要注意的就是tm结构体部分成员的值不是真实的值,需...

    发表评论

    访客

    ◎欢迎参与讨论,请在这里发表您的看法和观点。