今天學了怎么插入注冊表鍵和刪除注冊表鍵。也沒有什么特別的思路,主要是調用windows自帶的函數來完成操作。感想就是看MSND一定要仔細。看書也要仔細。哈哈。
奉上源代碼:
#include <iostream>
#include <Windows.h>
#include <assert.h>
//創建一個注冊表的鍵值。chKey為主鍵, chValue為鍵的路徑,值插入的默認的名中
bool SetRegKey( const HKEY& hKeyRoot, const char* chKey, const char* chValue)
{
assert(chKey);
HKEY hKey; //要插入的hkey
//創建或打開一個要插入的hkey
long lRes= ::RegCreateKeyExA(hKeyRoot, //插入的主鍵
chKey, //要創建的鍵名
0, //保留字
NULL, //lpClass貌似很強大,但是我知道有什么用
REG_OPTION_NON_VOLATILE, //操作屬性設置為不常改變
KEY_ALL_ACCESS, //權限設置為都可以用
NULL, //安全屬性為默認
&hKey, //保存創建好的key
NULL //得到返回類型是打開還是創建
);
if (lRes != ERROR_SUCCESS) //如果不成功返回false;
{
return false;
}
if (chValue != NULL) //如果要插入默認鍵值
{
::RegSetValueExA(hKey, NULL, 0, REG_SZ,(byte*)chValue, strlen(chValue)+1);
}
RegCloseKey(hKey); //關閉key
return true;
}
//清除注冊表值,hKeyPar為父節點的鍵值, chKey為鍵的
bool DeleteKey(const HKEY& hKeyPar, const char* chKey)
{
HKEY hKeySub; //要清除的hkey
//打開清除的hkey
long lRes = ::RegOpenKeyExA(hKeyPar, chKey, 0, KEY_ALL_ACCESS, &hKeySub);
if (lRes != ERROR_SUCCESS) //如果沒有,返回false
{
return false;
}
//遍歷key的所有子節點,并一并清除
char chBuffer[MAX_PATH];
unsigned long nSize = MAX_PATH;
//遍歷子節點,清除,這里注意nIndex一直為0,因為每次有刪除第0個子鍵,所以用0的索引就
//能遍歷刪除所有的子鍵。如果是查詢的話,就必須要改變nIndex來遍歷。還有就是注意nSize
//他是一個_in_out的參數,內部會改變他,所以每次都要把他設置為原來MAX_PATH
while (::RegEnumKeyExA(hKeySub, 0, chBuffer, &nSize, 0,0,0,0) == ERROR_SUCCESS)
{
//如果找到子鍵,就刪除子鍵
if (!DeleteKey(hKeySub, chBuffer))
{
::RegCloseKey(hKeySub);
return false;
}
nSize = MAX_PATH;
}
//需要先關閉該建,才能刪除它。
RegCloseKey(hKeySub);
//調用系統函數刪除該鍵
if (::RegDeleteKeyA(hKeyPar, chKey) != ERROR_SUCCESS)
{
return false;
}
return true;
}
int main()
{
SetRegKey(HKEY_CLASSES_ROOT, "MyTestRegInserKey", "MyTestRegInserKey");
SetRegKey(HKEY_CLASSES_ROOT, "MyTestRegInserKey\\cV1\\CC2", "MyTestRegInserKey");
SetRegKey(HKEY_CLASSES_ROOT, "MyTestRegInserKey\\cV1\\CC3", "MyTestRegInserKey");
DeleteKey(HKEY_CLASSES_ROOT, "MyTestRegInserKey");
system("pause");
return 0;
}