Почему разные процессы видят разные экземпляры папки 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-разрядными приложениями

Другие вопросы по тегам