VC操作注册表函数

14 篇文章 0 订阅

    1. 打开注册表键


LONG RegOpenKeyEx(
HKEY hKey,         // handle to open key主键
LPCTSTR lpSubKey,  // subkey name子键
DWORD ulOptions,   // reserved。必须是0
REGSAM samDesired, // security access mask读写标识
PHKEY phkResult    // handle to open key返回的HKEY类型的指针。以后,读写,关闭用这个指针
);

 

如:
// 打开HKEY_LOCAL_MACHINE主键下的SoftWare//Cleaner//Cleaner子键
HKEY hKEY;
HKEY  hKeyRoot = HKEY_LOCAL_MACHINE;
long ret0=(::RegOpenKeyEx(hKeyRoot,"SoftWare//Cleaner//Cleaner",0,KEY_READ,&hKEY));
if(ret0!=ERROR_SUCCESS)// 如果无法打开hKEY,则中止程序的执行
{
AfxMessageBox("错误:无法打开有关的hKEY");
return;
}

 

 

    2. 读取注册表


LONG RegQueryValueEx(
HKEY hKey,            // handle to key打开注册表指针
LPCTSTR lpValueName,  // value name要读取的键名称
LPDWORD lpReserved,   // reserved  must be NULL. 必须是NULL
LPDWORD lpType,       // type buffer,键类型。我最常用REG_SZ,REG_DWORD
LPBYTE lpData,        // data buffer。保存查询结果的缓冲区
LPDWORD lpcbData      // size of data buffer。缓冲区大小
);
如:
// hKEY是上面打开时得到的指针。
LPBYTE getValue = new BYTE[80];//得到的键值
DWORD keyType = REG_SZ;//定义数据类型
DWORD DataLen = 80;//定义数据长度
CString strUser = _T("Version");//要查询的键名称
long ret1=::RegQueryValueEx(hKEY,strUser,NULL,&keyType,getValue,&DataLen);
if(ret1!=ERROR_SUCCESS)
{
AfxMessageBox("错误:无法查询有关的注册表信息");
return;
}

 

 

    3. 写注册表


LONG RegSetValueEx(
HKEY hKey,           // handle to key。打开注册表的指针
LPCTSTR lpValueName, // value name 要写入的键
DWORD Reserved,      // reserved  必须是0
DWORD dwType,        // value type 写入值类型
CONST BYTE *lpData,  // value data 要写入的数据
DWORD cbData         // size of value data 。数据SIZE
);
如:
// 写注册表。修改Version为1.0.12
// 写入CString类型的数据
CString strVersion = _T("Version");//要写入的键名称
LPCTSTR strVersionValue = "1.0.12";
long ret = ::RegSetValueEx(hKEY, strVersion, 0, REG_SZ, (const BYTE *) strVersionValue, strlen(strVersionValue)+1);
if(ret!=ERROR_SUCCESS)
{
AfxMessageBox(" 错误:无法查询有关的注册表信息");
return;
}
 

 

    4. 创建一个新键


LONG RegCreateKeyEx(
HKEY hKey,                                  // handle to open key。打开的注册表指针
LPCTSTR lpSubKey,                           // subkey name。子键名称
DWORD Reserved,                             // reserved。必须为0
LPTSTR lpClass,                             // class string。已经存在时用,一般为NULL
DWORD dwOptions,                            // special options
//默认值REG_OPTION_VOLATILE,保存在注册表,下次开机仍然存在
//REG_OPTION_VOLATILE,保存在内存
//REG_OPTION_BACKUP_RESTORE
REGSAM samDesired,                          // desired security access。操作权限。一般KEY_ALL_ACCESS,除非有特殊需要,请查阅MSDN
LPSECURITY_ATTRIBUTES lpSecurityAttributes, // inheritance。继承性。一般为NULL
PHKEY phkResult,                            // key handle 。返回该键值镇。
LPDWORD lpdwDisposition                     // disposition value buffer
//REG_CREATED_NEW_KEY The key did not exist and was created.
//REG_OPENED_EXISTING_KEY The key existed and was simply opened without being changed.

);

 

 

    5. 删除一个键


LONG RegDeleteKey(
HKEY hKey,         // handle to open key
LPCTSTR lpSubKey   // subkey name
);

 

    6. 删除一个键值


LONG RegDeleteValue(
HKEY hKey,            // handle to key
LPCTSTR lpValueName   // value name。值名称,不是打开的那个指针,是查询到的指针,如果为空RegSetValueEx创建的值将被删除
);

 

    7. 刷新注册表


LONG RegFlushKey(
HKEY hKey   // handle to key to write。写入所有的值,在给定的指针
);

//这个函数是将改变数据直接写到硬盘上,不要频繁使用,会影响性能

 

    8.  导入一个注册表文件到指定的键下


LONG RegLoadKey(
HKEY hKey,        // handle to open key
LPCTSTR lpSubKey, // subkey name
LPCTSTR lpFile    // registry file name
);

//没有用

 

    9. 关闭打开的注册表


LONG RegCloseKey(
HKEY hKey   // handle to key to close
);

//打开的注册表的指针需要注意关闭释放

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值