在工作中如果使用到串口,我们在打开的时候,都要做如下操作:

1、右键“我的电脑”打开右键菜单;

2、然后选择并点击“管理”;

3、在弹出的计算机管理器中选择“设备管理器”;(有的右键菜单直接有设备管理器)

4、在右侧选择“端口”,展开看串口信息;

5、在软件中输入串口名,然后打开。

有没有什么办法省去这样的操作呢,直接在软件打开的时候(或者通过按钮刷新信息)获取到已有的串口列表信息?

注册表

在windows操作系统中,有很多设备和应用以及其他的很多东西都在它的注册表中。

只要我们读取注册表中相应的位置,就可以获取对应信息。

当然串口信息也不例外,它在注册表中的路径是:

HKEY_LOCAL_MACHINE\HARDWARE\DEVICEMAP\SERIALCOMM 。

大家可以在执行 regedit 打开注册表编辑器,打开对应位置查看串口信息(前提是有串口设备)。

我的电脑上信息如下图:

c语言如何查看串口号(CC编程笔记)(1)

对于如何读取注册表,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; }

总结

还有其他不少关于注册表操作的函数,

有兴趣的小伙伴可以自行查看和搜索相关函数功能和用法。

在这就不做展开了。

如果觉得我写的还不错的话,求赞,求关注哦!(^▽^)

,