在工作中如果使用到串口,我们在打开的时候,都要做如下操作:
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;
}
还有其他不少关于注册表操作的函数,
有兴趣的小伙伴可以自行查看和搜索相关函数功能和用法。
在这就不做展开了。
如果觉得我写的还不错的话,求赞,求关注哦!(^▽^)
,