c++读写注册表

转载:https://www.cnblogs.com/bksqmy/p/4551406.html

https://www.cnblogs.com/lightspeedsmallson/p/4901211.html

1.说明: 
    注册表是Windows重要组成部分,注册表记录了大量有关电脑软硬件的信息。注册表中的值通过其名称标识。值名称由与键名相同的字符组成。值本身可以是字符串、二进制数据或者是32位无符号值。

2.预定义的注册表键。注册表包含了几个预定义键:

  • HKEY_LOCAL_MACHINE 包含描述计算机及其配置的条目。其中包括关于处理器、系统主板、内存和已安装的软件和硬件的信息。  
  • HKEY_CLASSES_ROOT 是与文档类型和 OLE\COM 相关的信息的支持键。这个键是 HKEY_LOCAL_MACHINE的从属键。  
  • HKEY_USERS 用作默认用户首选设置,也作为单个用户的首选设置。  
  • HKEY_CLASSES_USER 是用于当前(登录)用户的相关信息。  
  • HKEY_CURRENT_CONFIG 包含了当前系统配置的信息。  
  • 还有一个,一般不会出现,只有配置的局域网后才会有

3.CRegKey 类及主要使用和函数说明

所需要头文件:atlbase.h  

☆ 打开一个键的函数:RegOpenKeyEx
   函数定义:
1 LONG RegOpenKeyEx(HKEY hKey,//已经打开的键的句柄,或者直接是上述几个根键
2                                LPCTSTR lpSubKey,//要打开的子键名字的地址
3                                DWORD ulOptions,//保留值,必须为0
4                                REGSAM samDesired,//打开方式,如读还是写
5                                PHKEY phkResult//返回的打开的子键的句柄
6                               );
☆ 查询某一个键值:RegQueryValueEx
   函数定义:
1 LONG RegQueryValueEx(HKEY hKey,//要查询的键的句柄
2                                   LPCTSTR lpValueName,//要查询的键值的名称
3                                   LPDWORD lpReserved,//保留值
4                                   LPDWORD lpType,//要查询的数据的类型
5                                   LPBYTE lpData,//要返回的查询的数据
6                                   LPDWORD lpcbData//预置的数据的长度
7                                  );
☆ 设置一个键值RegSetValueEx
   函数定义:
1 LONG RegSetValueEx(HKEY hKey,//要设置的键的句柄
2                                 LPCTSTR lpValueName,//要访问的键值的名称
3                                 LPDWORD lpReserved,//保留值
4                                 DWORD dwType,//要设置的数据的类型
5                                 const BYTE *lpData,//要设置的健值
6                                 DWORD cbData//数据的长度
7                                );

4.实例:

 1 void writeRegSz(char *uniqueId)
 2 {
 3     HKEY hkey;
 4     HKEY hTempKey;
 5     char m_name_set[256] = "China";
 6 
 7     DWORD len = strlen(uniqueId) + 1;
 8     LPCTSTR data_set = _T("System");
 9     if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_CURRENT_USER, data_set, 0, KEY_SET_VALUE, &hkey))
10     {
11         if (ERROR_SUCCESS == ::RegCreateKey(hkey, _T("test1112"), &hTempKey))
12         {
13             if (ERROR_SUCCESS != ::RegSetValueEx(hTempKey, _T("Name"), 0, REG_SZ, (const BYTE*)uniqueId, len))
14             {
15                 cout << "写入错误" << endl;
16             }
17         }
18         else
19         {
20             cout << "创建key错误" << "\n";
21         }
22     }
23     else
24     {
25         cout << "打开注册表错误" << "\n";
26     }
27     ::RegCloseKey(hkey);
28 }

 

原文链接: https://www.cnblogs.com/Toya/p/12373857.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;

也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬

    c++读写注册表

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/332168

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年3月1日 下午6:22
下一篇 2023年3月1日 下午6:23

相关推荐