Windows CE 6.0注冊表應用示例
Windows CE 6.0有4個基本的注冊表鍵值, HKEY_CLASSES_ROOT, HKEY_CURRENT_USER, HKEY_LOCAL_MACHINE, HKEY_USERS。其它的都是這4個注冊表的子鍵。
我們以一個內建的串口驅動為例,它在注冊表文件Platform.reg中的描述如下: 其中Prefix 和 Dll項是必不可少的,Prefix代表設備文件名前綴, 與Index合用表示該設備的名稱,該注冊表子鍵的設備名稱就是"COM1:",該名稱可以用于CreateFile調用。Dll則是動態鏈接庫名稱。 Index為設備序號。Flags為1表示系統啟動時不加載,需要應用程序自己加載,為0表示該驅動在系統啟動時加載。
- [HKEY_LOCAL_MACHINE\Drivers\BuiltIn\Serial]
- "Prefix"="COM"
- "Dll"="$(_TGTPLAT_PFX)_serial.dll"
- "Flags"=dword:0
- "Index"=dword:1
在%WinCE Dir%Public%Common%OAK%INC%目錄下,文件cregedit.h中,定義了一個類CRegistryEdit來封裝了注冊表的操作。許多的硬件驅動,比如串口類,也繼承了CRegistryEdit類。
還有一種方法是利用windows CE提供的API進行注冊表項的操作。
方法一: 利用系統提供的注冊表類CRegistryEdit
類的定義在文件regedit.h中。
在構建函數中,會取得當前注冊表子鍵的HANDLE句柄。有3個構造函數,第一個是用全路徑,調用hKey = OpenDeviceKey(TEXT("HKEY_LOCAL_MACHINE\\Drivers\\BuiltIn\\Serial"))構造, 第二個是如果已知其父注冊表子鍵,調用RegOpenKeyEx( HKEY_LOCAL_MACHINE, TEXT("Drivers\\BuiltIn\\Serial"), 0,0,&hKey). 第三種方法是用RegCreateKeyEx().
析構函數中,調用RegCloseKey(hKey)關閉掉對注冊表子鍵的引用。
讀取注冊表項可以使用GetRegValue方法,寫入注冊表項使用RegSetValueEx方法。其方法的實現也是通過windows CE API,具體可以參照下一個Section。
RegGetList和RegSetList方法提供了對類型為REG_MULTI_SZ和DWORD的VALUE的讀寫操作。
其它類方法GetWindowInfo, GetIsrInfo,GetPciInfo獲取注冊表更多的信息。
方法二: 利用windows CE API
為了獲取一個注冊表鍵值,先要調用RegOpenKeyEx。以上面內建串口驅動為例,RegOpenKey( HKEY_LOCAL_MACHINE, TEXT("Drivers\\BuiltIn\\Serial"), 0, 0, &hKey ), 其中hKey就是我們獲取的該注冊表子鍵的HANDLE句柄。接下來對注冊表子鍵的操作就是通過hKey來實現.
有了hKey, 就可以對注冊表子鍵的各個內容進行讀寫操作。如果要讀去子鍵的Prefix, 調用函數RegQueryValueEx(hKey, TEXT("Prefix"), NULL, &lpType, &lpData, &lpcbData), lpType, lpData為Prefix返回類型和值,該例中,lpType = REG_SZ, lpData = TEXT("COM"). lpcbData當調用時,修飾限制lpData的size in bytes,返回時,為lpData返回值的SIZE。
對應于讀操作,寫操作是一個相反的過程,RegSetValueEx(hKey, TEXT("Prefix"), NULL, REG_SZ, PBYTE(TEXT("TST")), wcslen(TEXT("TST"))*2). 其中要寫入的項為Prefix項,類型為REG_SZ, 值為TEXT("TST"), 最后一個參數為寫入值得SIZE in bytes. 注意第二個參數,如果注冊表中存在該項,則改寫它的值。如果沒有,則新建一個注冊表項。
某些情況下,我們需要刪除一個注冊表項,只需調用RegDeleteKey(hKey, TEXT("Index"))就可以刪除Index注冊表項。
要關閉一個注冊表子鍵,只需要調用RegCloseKey(hKey)就可以完成。
關于注冊表有很多更加深入的使用,如RegEnumValue. 更多有關注冊表項,可以查看MSDN手冊。
【編輯推薦】