Почему разные процессы видят разные экземпляры папки System32?
Я использую Windows 8 Enterprise x64. Я вошел в систему, используя учетную запись из группы администраторов. Когда я открываю Windows Explorer или командную строку, я вижу файл cdd.dll
:
C:\Windows\system32>dir cdd.dll
Volume in drive C has no label.
Volume Serial Number is ▨▨▨▨-▨▨▨▨
Directory of C:\Windows\system32
07/25/2012 09:49 PM 199,680 cdd.dll
Но если я открою диалоговое окно "Открыть файл" из браузера Chrome, Visual Studio или некоторых других приложений (все они являются 32-разрядными приложениями) и перейду к C:\Windows\system32
тогда такого файла нет (фильтр настроен на отображение всех файлов). И если я вызову пункт контекстного меню "Открыть командное окно здесь", используя Shift+RightClick в диалоговом окне "Открыть файл", введите dir
это подтверждает, что такого файла нет:
C:\Windows\System32>dir cdd.dll
Volume in drive C has no label.
Volume Serial Number is ▨▨▨▨-▨▨▨▨
Directory of C:\Windows\System32
File Not Found
Этот эффект не является специфическим для cdd.dll
многие другие файлы также отличаются. Мне сказали, что это эффект виртуализации файловой системы, о которой я очень мало знаю.
Не могли бы вы объяснить или дать мне ссылку, которая объясняет, как это на самом деле работает? Есть ли на самом деле несколько разных случаев System32
папка. Каково их физическое расположение на диске? Можно ли получить доступ из 32-битных файлов процесса в другой System32
папка, показанная 32-битным процессам по умолчанию.
2 ответа
Проблема заключается в перенаправлении папок, если 32-битная программа пытается получить доступ к %windir%\System32
папка будет незаметно перенаправлена в %windir%\SysWOW64
каталог, это для 32/64-битной совместимости приложений.
Все файлы в System32 являются 64-битными, однако, если программа была написана неправильно, они, возможно, жестко закодировали System32 в своей программе при поиске DLL. Чтобы предотвратить случайные сбои программы от неправильно написанных программ, Microsoft делает это перенаправление.
Если вам нужен доступ к папке System32, а не к папке SysWOW64, перейдите в "скрытую" папку %windir%\sysnative
который перенесет вас в "настоящий" System32
папку, и вы можете просматривать папку, как обычно.
WOW64 (Windows на Windows 64bit) использует различные технологии / методы для поддержки 32-битных приложений. Среди них редиректоры папок и реестра.
Центр разработки Windows: рабочий стол с 32-разрядными приложениями