RegQueryValueEx简体中文详细注释

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

功能:找回所打开注册表键所关联的一个给定值的类型和数据。

LONG RegQueryV alueEx(

HKEY hKey, // 要查询键的句柄

LPTSTR lpV alueName, // 要查询值的名字的地址

LPDWORD lpReserved, // 保留

LPDWORD lpType, // 值类型缓存地址

LPBYTE lpData, // 数据缓存地址

LPDWORD lpcbData // 数据缓存大小地址);

参数:

hKey

一个当前已打开键的句柄或下列已确定的保留句柄值:

HKEY_CLASSES_ROOT

HKEY_CURRENT_CONFIG

HKEY_CURRENT_USER

HKEY_LOCAL_MACHINE

HKEY_USERS

Windows NT: HKEY_PERFORMANCE_DA TA

Windows 95和Windows 98: HKEY_DYN_DA TA

lpValueName

指向要查询值的名字的字符串(以空字符结束)。

如果lpV alueName是NULL或一个空字符串(""),这个函数找回这个键的未命名或默认值的类型和数据。

Windows 95和Windows 98: 每个键有一个默认值(最初的不包含数据)。在Windows 95,这人默认值类型总是REG_SZ。在Windows 98,默认键的类型最初是REG_SZ,但可以通过RegSetV alueEx指定一个默认值为不同的类型。

Windows NT: 键不能自动拥有一个未命名或默认的值,未命名的值可以是任何类型

lpReserved

保留,必须是NULL.

lpT ype

指向与给定值相关联数据的类型的变量。这个值将通过这个参数返回,将是下面之一:

值含意

REG_BINARY二进制数据。

REG_DWORD一个32位数字。

REG_DWORD_LITTLE_ENDIAN一个little-endian格式的32位数字。这相当于REG_DWORD。

ittle-endian格式,是一个多字节值在内存中被从低字节到高字节存贮。如,值0x12345678在little-endian格式中被存贮为(0x78 0x56 0x34 0x12)。

Windows NT, Windows 95,和Windows 98是有意运行在little-endian计算机体系上的。例如像一些UNIX系统,一个用户必须连接到big-endian体系的计算机上。

REG_DWORD_BIG_ENDIAN一个big-endian格式的32位数字。

big-endian格式,一个多字节值在内存职被从高字节到低字节存贮。如,值0x12345678在big-endian格式中被存贮为(0x120x34 0x56 0x78)。

REG_EXPAND_SZ一个包含未被引用的环境变量的以空字符结束的字符串(如,"%PA TH%")。它是Unicode字符串还是ANSI字符串将依赖你所使用的是Unicode函数还是ANSI函数。扩展环境变量引用,使用ExpandEnvironmentStrings函数。

REG_LINK一个Unicode符号连接。

REG_MULTI_SZ一个以空字符结束的字符串数组,被两个null字符结束。

REG_NONE未定义值类型。

REG_RESOURCE_LIST一个设备驱动资源列表。

REG_SZ一个以空字符结束的字符串。它是Unicode字符串还是ANSI字符串将依赖你所使用的是Unicode函数还是ANSI函数。

如果不需要类型lpType参数可以为空(NULL)。

lpData

指定接收值数据的缓存区。如果数据是不需要的这个参数可以为空。

lpcbData

以字节为单位,指向lpData参数所指定地缓存区大小的变量。函数返回复制到lpData 的数据大小的变量。

如果数据是REG_SZ、REG_MULTI_SZ或REG_EXPAND_SZ类型,那么lpcbData还将包括以空字符结束的大小。

如果lpData是NULL,lpcbData参数可以是NULL。

如果被lpData参数指定的缓存不够大,这个函数返回ERROR_MORE_DA TA值,并取回被lpcbData指定的变量缓存的大小(以字节为单位)。

如果lpData是NULL,lpcbData不是NULL,这个函数返回ERROR_SUCCESS,并取回被lpcbData指定的变量缓存的大小(以字节为单位)。这个为值的数据缓存分配最好的途径。

Window NT:

如果hKey指定为HKEY_PERFORMANCE_DA TA,并且lpData缓存太小,RegQueryV alueEx返回ERROR_MORE_DA TA,但是lpcbData不能返回必需的缓存大小。这是因为运用数据的大小可以在调用的下一步被改变。在这种情形下,你必须增加缓存的大小并重新调用RegQueryV alueEx通过lpcbData

参数更新缓存大小。重复直到函数成功。你需要维护一个单独的变量去留意缓存的大小。因为被lpcbData返回的值是可不预知的。

返回值

如果这个函数成功,返回ERROR_SUCCESS。

如果调有失败,返回一个非零错误码(定义在WINERROR.H)。你可以使用带有FORMA T_MESSAGE_FROM_SYSTEM标记的FormatMessage函数获得错误的普通描述信息。

注意

被hKey确定的键必须是被带有KEY_QUERY_V ALUE标记打开的。打开键,使用RegCreateKeyEx函数或RegOpenKeyEx函数。

如果值数据是REG_SZ、REG_MULTI_SZ或REG_EXPAND_SZ类型,这个函数的ANSI版本将被使用(明确的调用RegQueryV alueExA或在包含WINDOWS.H文件前不定义UNICODE),这个函数在复制它到lpData指定的缓存中以前,转换存贮地Unicode字符串为ANSI字符串。

相关文档
最新文档