我正在拨打以下电话:

result = RegOpenKeyEx(key, s, 0, KEY_READ, &key);

(C ++,Visual Studio 5,Vista 64bit)。

即使“ regedit ”,它也会失败并显示错误代码2(“找不到文件”)表明密钥存在。这段代码一直在32位XP上运行。为什么“找不到文件”?什么时候显然呢?

有帮助吗?

解决方案

我发现我可以使用标志解决我的问题: KEY_WOW64_64KEY ,如:

result = RegOpenKeyEx(key, s, 0, KEY_READ|KEY_WOW64_64KEY, &key);

有关完整说明: 32位和64-在注册表中列出应用程序数据

其他提示

在Windows 64位系统上,注册表实际上分为两部分。一个部分由64位进程使用,一部分由32位进程使用。

例如,如果32位应用程序以编程方式写入其认为是HKLM \ SOFTWARE \ Company \ Application的内容,则它实际上由WoW64层重定向到HKLM \ SOFTWARE \ Wow6432Node \ Company \ Application。

因此,当您运行32位应用程序并调用RegOpenKeyEx时,它实际上是针对Wow6432Node \文件夹而不是常规\ SOFTWARE节点。

您必须使用“使用多字节字符集”进行编译。或者将代码中的字符串转换为(LPWSTR)

我有类似的问题。 我正在使用:

dwResult = RegOpenKeyEx(HKEY_LOCAL_MACHINE,
                                   (LPWSTR)"SOFTWARE\\0test",
                                   0,
                                   WRITE_DAC ,
                                   &hKey);

那不起作用。我尝试过这样做并且有效:

dwResult = RegOpenKeyEx(HKEY_LOCAL_MACHINE,
                                   _T("SOFTWARE\\0test"),
                                   0,
                                   WRITE_DAC ,
                                   &hKey);

是, win7 64B,进一步添加标志KEY_WOW64_64KEY,它将起作用。 如果不起作用,请参阅 http:// msdn。 microsoft.com/en-us/library/ms724897(v=VS.85).aspx

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top