基于重啟后消失的注冊表鍵值的詳細(xì)介紹
更新時間:2013年05月17日 17:01:45 作者:
本篇文章是對重啟后消失的注冊表鍵值進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
今天遇到一個bug,折騰了半天才解決掉,分享給大家。
Bug描述
一位開發(fā)人員調(diào)用下面的代碼來創(chuàng)建一個注冊表鍵值:
HKEY hKey;
if(::RegOpenKeyEx(HKEY_CURRENT_USER, DemoRegKey, 0, KEY_WRITE, &hKey) != ERROR_SUCCESS)
{
RegCreateKeyEx(HKEY_CURRENT_USER, DemoRegKey, 0, NULL, REG_OPTION_VOLATILE
, KEY_ALL_ACCESS , NULL , &hKey, NULL);
}
執(zhí)行后,成功的在注冊表編輯器中看到了鍵值,后續(xù)從中獲取值等代碼沒有任何問題。
提交測試后發(fā)現(xiàn),當(dāng)系統(tǒng)重啟后,上面的程序創(chuàng)建的注冊表鍵值都沒有了,導(dǎo)致后面讀取鍵值的代碼都報錯。
Why?
隨后我調(diào)整了代碼,發(fā)現(xiàn)下面的代碼在重啟后得到的錯誤碼是2
LONG lRet;
lRet = ::RegOpenKeyEx(HKEY_CURRENT_USER, DemoRegKey, 0, KEY_WRITE, &hKey);
執(zhí)行這段代碼lRet的值是2. 錯誤碼2的意思是:系統(tǒng)找不到指定的文件。 對于注冊表函數(shù)而已,就是對應(yīng)的鍵不存在。
調(diào)試后發(fā)現(xiàn),創(chuàng)建注冊表的代碼的確成功執(zhí)行了,在注冊表中也可以看得到。同時,再調(diào)用讀取鍵值的代碼,也沒有任何問題。但是一旦重啟電腦,路徑就不存在了,里面保存的鍵值都沒有了。
看來是某些程序刪掉了我的鍵值,于是查找所有刪除鍵值的代碼,沒有找到。
在重啟前將所有的程序都刪除掉。但是重啟后,該死的鍵值還是沒有出現(xiàn)。
看來是系統(tǒng)或者其它程序刪除的。難道我的鍵值和某些程序的鍵值重名了?好,這次用guid做鍵名,還是重啟后沒有了。
哇哇,真是抓狂啊。
這時候,我回過頭來再細(xì)看所有創(chuàng)建注冊表相關(guān)的代碼,因為必定是我的程序?qū)е骆I值消失的。
我注意到了REG_OPTION_VOLATILE 這個奇怪的參數(shù)。
MSDN之后,我終于找到了原因,就是這個參數(shù)造成的。
原因
REG_OPTION_VOLATILE 這個參數(shù)的意思是創(chuàng)建的注冊表鍵值都位于內(nèi)存中,不會保存到相應(yīng)的注冊表文件中。
英文如下:
All registry keys are created as volatile, and the information is stored in memory and is not preserved when the corresponding registry hive is unloaded. For HKEY_LOCAL_MACHINE, this occurs when the OS is shut down. The RegSaveKey function does not save volatile registry keys. This flag is ignored for keys that already exist.
所以,重啟后這些鍵值當(dāng)然就沒有了。
解決辦法
很簡單,使用REG_OPTION_NON_VOLATILE 即可
RegCreateKeyEx(HKEY_CURRENT_USER, DemoRegKey, 0, NULL, REG_OPTION_NON_VOLATILE
, KEY_ALL_ACCESS , NULL , &hKey, NULL);
這個可以用在測試上。一重啟,之前創(chuàng)建的鍵值都沒了。
Bug描述
一位開發(fā)人員調(diào)用下面的代碼來創(chuàng)建一個注冊表鍵值:
復(fù)制代碼 代碼如下:
HKEY hKey;
if(::RegOpenKeyEx(HKEY_CURRENT_USER, DemoRegKey, 0, KEY_WRITE, &hKey) != ERROR_SUCCESS)
{
RegCreateKeyEx(HKEY_CURRENT_USER, DemoRegKey, 0, NULL, REG_OPTION_VOLATILE
, KEY_ALL_ACCESS , NULL , &hKey, NULL);
}
執(zhí)行后,成功的在注冊表編輯器中看到了鍵值,后續(xù)從中獲取值等代碼沒有任何問題。
提交測試后發(fā)現(xiàn),當(dāng)系統(tǒng)重啟后,上面的程序創(chuàng)建的注冊表鍵值都沒有了,導(dǎo)致后面讀取鍵值的代碼都報錯。
Why?
隨后我調(diào)整了代碼,發(fā)現(xiàn)下面的代碼在重啟后得到的錯誤碼是2
復(fù)制代碼 代碼如下:
LONG lRet;
lRet = ::RegOpenKeyEx(HKEY_CURRENT_USER, DemoRegKey, 0, KEY_WRITE, &hKey);
執(zhí)行這段代碼lRet的值是2. 錯誤碼2的意思是:系統(tǒng)找不到指定的文件。 對于注冊表函數(shù)而已,就是對應(yīng)的鍵不存在。
調(diào)試后發(fā)現(xiàn),創(chuàng)建注冊表的代碼的確成功執(zhí)行了,在注冊表中也可以看得到。同時,再調(diào)用讀取鍵值的代碼,也沒有任何問題。但是一旦重啟電腦,路徑就不存在了,里面保存的鍵值都沒有了。
看來是某些程序刪掉了我的鍵值,于是查找所有刪除鍵值的代碼,沒有找到。
在重啟前將所有的程序都刪除掉。但是重啟后,該死的鍵值還是沒有出現(xiàn)。
看來是系統(tǒng)或者其它程序刪除的。難道我的鍵值和某些程序的鍵值重名了?好,這次用guid做鍵名,還是重啟后沒有了。
哇哇,真是抓狂啊。
這時候,我回過頭來再細(xì)看所有創(chuàng)建注冊表相關(guān)的代碼,因為必定是我的程序?qū)е骆I值消失的。
我注意到了REG_OPTION_VOLATILE 這個奇怪的參數(shù)。
MSDN之后,我終于找到了原因,就是這個參數(shù)造成的。
原因
REG_OPTION_VOLATILE 這個參數(shù)的意思是創(chuàng)建的注冊表鍵值都位于內(nèi)存中,不會保存到相應(yīng)的注冊表文件中。
英文如下:
復(fù)制代碼 代碼如下:
All registry keys are created as volatile, and the information is stored in memory and is not preserved when the corresponding registry hive is unloaded. For HKEY_LOCAL_MACHINE, this occurs when the OS is shut down. The RegSaveKey function does not save volatile registry keys. This flag is ignored for keys that already exist.
所以,重啟后這些鍵值當(dāng)然就沒有了。
解決辦法
很簡單,使用REG_OPTION_NON_VOLATILE 即可
復(fù)制代碼 代碼如下:
RegCreateKeyEx(HKEY_CURRENT_USER, DemoRegKey, 0, NULL, REG_OPTION_NON_VOLATILE
, KEY_ALL_ACCESS , NULL , &hKey, NULL);
這個可以用在測試上。一重啟,之前創(chuàng)建的鍵值都沒了。
相關(guān)文章
C++實現(xiàn)LeetCode(102.二叉樹層序遍歷)
這篇文章主要介紹了C++實現(xiàn)LeetCode(102.二叉樹層序遍歷),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C++?MiniZip實現(xiàn)目錄壓縮與解壓的示例詳解
Zlib是一個開源的數(shù)據(jù)壓縮庫,提供了一種通用的數(shù)據(jù)壓縮和解壓縮算法,本文主要為大家詳細(xì)介紹了如何利用Zlib實現(xiàn)目錄壓縮與解壓,需要的小伙伴可以參考下2023-11-11Dev C++編譯時運行報錯source file not compile問題
這篇文章主要介紹了Dev C++編譯時運行報錯source file not compile問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01Linux下C語言的幾道經(jīng)典面試題小結(jié)(分享)
下面小編就為大家?guī)硪黄狶inux下C語言的幾道經(jīng)典面試題小結(jié)(分享)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05