我想检测以“HKEY_LOCAL_MACHINE\SOFTWARE\blah\SetupPath”开头的注册表项,如果可能的话读取到 CString。
我在 MSDN 上看到了 RegOpenKeyEx 函数
LONG WINAPI RegOpenKeyEx(
_In_ HKEY hKey,
_In_opt_ LPCTSTR lpSubKey,
_Reserved_ DWORD ulOptions,
_In_ REGSAM samDesired,
_Out_ PHKEY phkResult
);
为此,我似乎需要设置一些东西。
HKEY hKey = HKEY_LOCAL_MACHINE;
LPCTSTR lpSubKey = "SOFTWARE\blah\SetupPath";
然后查看 key 是否存在
LONG res = RegOpenKeyEx(hKey, lpSubKey, 0, 0, 0);
if(res == ERROR_SUCCESS)
// The key exists
现在,如果 key 存在,我想将其中的内容读取到 CString 中。我还看到了 RegQueryValueEx
LONG WINAPI RegQueryValueEx(
_In_ HKEY hKey,
_In_opt_ LPCTSTR lpValueName,
_Reserved_ LPDWORD lpReserved,
_Out_opt_ LPDWORD lpType,
_Out_opt_ LPBYTE lpData,
_Inout_opt_ LPDWORD lpcbData
);
在调用此函数之前,我似乎还需要一些设置。
HKEY hKey = HKEY_LOCAL_MACHINE;
lpSubKey = "SOFTWARE\blah\SetupPath";
LPDWORD type = null;
LPDWORD data = null;
现在我可以调用它了
LONG res2 = RegValueQueryEX(hKey, lpSubKey, 0, type, data,0);
然后我想我可以检查类型然后转换为字符串?
CString regVal;
if(res2 == ERROR_SUCCESS)
if(type == REG_SZ)
if(data != null)
regVal = new CString((LPSTR)data);
这一切都正确吗?我可能缺少或需要做什么?
最佳答案
不,那是不正确的。您的主要误解是指针在 C++ 中的工作方式。为指针参数提供 NULL 是不够的,您必须提供指向变量的指针,以便 RegOpenKeyEx
或 RegValueQueryEx
例程可以返回该变量的值。您似乎还误解了如何分配给 CString
(不需要 new
)。最后,虽然这不是错误,但您不需要进行“设置”,您只需将值直接传递给函数即可。
先打开 key
HKEY key;
RegOpenKeyEx(HKEY_LOCAL_MACHINE, "SOFTWARE\\blah", 0, 0, &key);
然后获取值
DWORD type, size;
char data[99];
size = sizeof(data);
RegQueryValueEx(key, "SetupPath", 0, &type, (BYTE*)data, &size);
然后将值分配给您的 CString
CString regval(data);
最后关上 key
RegCloseKey(key);
该代码中没有错误检查,您应该添加它。此外,我假设您可以获得的任何值都适合 99 个字节,这可能不是真的。
请注意我如何将指针传递给 key
变量,以便 RegOpenKeyEx
可以返回 key 。然后,我在调用 RegValueQueryEx
和 RegCloseKey
时使用该键。 type
和 size
变量也是如此。另请注意,我已将调用 RegOpenKeyEx
和 RegValueQueryEx
的路径分开。我认为是正确的。
不能 100% 确定这是正确的,我还没有测试过,但应该更接近一些。
关于c++ - 读取和写入注册表项。 C++ MFC MBCS。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16063954/