在工作中如果使用到串口,我們在打開的時候,都要做如下操作:
1、右鍵“我的電腦”打開右鍵菜單;
2、然後選擇并點擊“管理”;
3、在彈出的計算機管理器中選擇“設備管理器”;(有的右鍵菜單直接有設備管理器)
4、在右側選擇“端口”,展開看串口信息;
5、在軟件中輸入串口名,然後打開。
有沒有什麼辦法省去這樣的操作呢,直接在軟件打開的時候(或者通過按鈕刷新信息)獲取到已有的串口列表信息?
注冊表在windows操作系統中,有很多設備和應用以及其他的很多東西都在它的注冊表中。
隻要我們讀取注冊表中相應的位置,就可以獲取對應信息。
當然串口信息也不例外,它在注冊表中的路徑是:
HKEY_LOCAL_MACHINE\HARDWARE\DEVICEMAP\SERIALCOMM 。
大家可以在執行 regedit 打開注冊表編輯器,打開對應位置查看串口信息(前提是有串口設備)。
我的電腦上信息如下圖:
對于如何讀取注冊表,windows 提供的豐富API中就有一系列與注冊表相關的接口。
今天我們需要用到的是如下幾個接口:
RegOpenKeyEx 用于打開所要的鍵,并返回一個句柄;
RegEnumValue 用于枚舉所在項的鍵值;
RegCloseKey 用于關閉當前打開的鍵。
使用方法具體調用流程如下:
#include <iostream>
#include <winreg.h> // 注冊表函數所在頭文件
using namespace std;
// 該函數返回讀取到的串口名稱列表
std::list<std::string> getComList()
{
std::list<std::string> listComs;
HKEY hKey;
// 打開注冊表
if(::RegOpenKeyEx(HKEY_LOCAL_MACHINE,
TEXT("HARDWARE\\DEVICEMAP\\SERIALCOMM"),
0,KEY_READ,&hKey)!=0)
return listComs;
char key[256]; //鍵名數組
char value[256]; //鍵值數組
DWORD type;
DWORD keySize;
DWORD valueSize;
DWORD idx = 0;
while (true) {
keySize = sizeof(key);
valueSize = sizeof(value);
//枚舉鍵值
int ret = ::RegEnumValueA(hKey,idx ,key,&keySize,0,
&type,(BYTE*)value,&valueSize);
if(ret == ERROR_SUCCESS || ret == ERROR_MORE_DATA) //列舉鍵名和值
{
listComs.push_back(value); // 保存獲取到的值
std::cout << value << std::endl;
}
else
break;
}
::RegCloseKey(hKey);//關閉注冊表
return listComs;
}
還有其他不少關于注冊表操作的函數,
有興趣的小夥伴可以自行查看和搜索相關函數功能和用法。
在這就不做展開了。
如果覺得我寫的還不錯的話,求贊,求關注哦!(^▽^)
,