Aquí es un poco de pseudo-código para recuperar el siguiente:
- Si existe una clave del Registro
- Lo que el valor predeterminado es para que la clave de registro
- Qué valor de cadena es
- Qué valor DWORD es
código
Ejemplo:
Incluir la dependencia de biblioteca: Advapi32.lib
HKEY hKey;
LONG lRes = RegOpenKeyExW(HKEY_LOCAL_MACHINE, L"SOFTWARE\\Perl", 0, KEY_READ, &hKey);
bool bExistsAndSuccess (lRes == ERROR_SUCCESS);
bool bDoesNotExistsSpecifically (lRes == ERROR_FILE_NOT_FOUND);
std::wstring strValueOfBinDir;
std::wstring strKeyDefaultValue;
GetStringRegKey(hKey, L"BinDir", strValueOfBinDir, L"bad");
GetStringRegKey(hKey, L"", strKeyDefaultValue, L"bad");
LONG GetDWORDRegKey(HKEY hKey, const std::wstring &strValueName, DWORD &nValue, DWORD nDefaultValue)
{
nValue = nDefaultValue;
DWORD dwBufferSize(sizeof(DWORD));
DWORD nResult(0);
LONG nError = ::RegQueryValueExW(hKey,
strValueName.c_str(),
0,
NULL,
reinterpret_cast<LPBYTE>(&nResult),
&dwBufferSize);
if (ERROR_SUCCESS == nError)
{
nValue = nResult;
}
return nError;
}
LONG GetBoolRegKey(HKEY hKey, const std::wstring &strValueName, bool &bValue, bool bDefaultValue)
{
DWORD nDefValue((bDefaultValue) ? 1 : 0);
DWORD nResult(nDefValue);
LONG nError = GetDWORDRegKey(hKey, strValueName.c_str(), nResult, nDefValue);
if (ERROR_SUCCESS == nError)
{
bValue = (nResult != 0) ? true : false;
}
return nError;
}
LONG GetStringRegKey(HKEY hKey, const std::wstring &strValueName, std::wstring &strValue, const std::wstring &strDefaultValue)
{
strValue = strDefaultValue;
WCHAR szBuffer[512];
DWORD dwBufferSize = sizeof(szBuffer);
ULONG nError;
nError = RegQueryValueExW(hKey, strValueName.c_str(), 0, NULL, (LPBYTE)szBuffer, &dwBufferSize);
if (ERROR_SUCCESS == nError)
{
strValue = szBuffer;
}
return nError;
}
Si por alguna razón inexplicable, parece que nunca encuentra una clave, puede tratarse de un problema de 32 bits/64 bits. Consulte http://stackoverflow.com/q/15084380/482758 – mkjeldsen
. Puede ser útil mencionar que su código está destinado a ser utilizado con lo que Windows llama un conjunto de caracteres Unicode. Cambiaría las llamadas de función 'RegOpenKeyExW' y' RegQueryValueExW' a su "equivalente de conjunto de caracteres" equivalente agnóstico 'RegOpenKeyEx' y' RegQueryValueEx' – HaMster
Unicode es predeterminado, solo fallará si alguien cambia explícitamente proyecto a byte múltiple que no existe razón para hacer – paulm