部分方式没结果,思路应该是没错。

  //7.
std::cout << "M8: SetupDiGetClassDevs " << std::endl;
//HDEVINFO hDevInfoSet = SetupDiGetClassDevs(&GUID_DEVINTERFACE_COMPORT, nullptr, nullptr, DIGCF_PRESENT | DIGCF_DEVICEINTERFACE);
HDEVINFO hDevInfoSet = SetupDiGetClassDevs(&GUID_DEVINTERFACE_SERENUM_BUS_ENUMERATOR, nullptr, nullptr, DIGCF_PRESENT);
if (hDevInfoSet != INVALID_HANDLE_VALUE)
{
int nIndex = ;
while (true)
{
SP_DEVINFO_DATA spDevInfo;
spDevInfo.cbSize = sizeof(SP_DEVINFO_DATA);
if (SetupDiEnumDeviceInfo(hDevInfoSet, nIndex++, &spDevInfo))
{
ATL::CRegKey RegKey;
RegKey.Attach(SetupDiOpenDevRegKey(hDevInfoSet, &spDevInfo, DICS_FLAG_GLOBAL, , DIREG_DEV, KEY_QUERY_VALUE)); unsigned char szSerialPort[] = { };
unsigned long szSerialPortSize = sizeof(szSerialPort);
if (ERROR_SUCCESS == RegKey.QueryStringValue("PortName", (char*)szSerialPort, &szSerialPortSize))
{
std::cout << szSerialPort << std::endl;
}
RegKey.Detach();
RegKey.Close();
continue;
}
break;
}
SetupDiDestroyDeviceInfoList(hDevInfoSet);
} //6. //test: win7 no results
std::cout << "M6: WMI " << std::endl;
//HRESULT hResult = CoInitialize(nullptr);
HRESULT hResult = CoInitializeEx(NULL, COINIT_APARTMENTTHREADED);
if (!FAILED(hResult))
{
hResult = CoInitializeSecurity(nullptr, -, nullptr, nullptr, RPC_C_AUTHN_LEVEL_DEFAULT, RPC_C_IMP_LEVEL_IMPERSONATE, nullptr, EOAC_NONE, nullptr); if (!FAILED(hResult))
{
IWbemLocator* pLocator = NULL;
//ATL::CComPtr<IWbemLocator> pLocator;
hResult = CoCreateInstance(CLSID_WbemLocator, nullptr, CLSCTX_INPROC_SERVER, IID_IWbemLocator, reinterpret_cast<void**>(&pLocator));
if (!FAILED(hResult))
{
IWbemServices* pServices = NULL;
//ATL::CComPtr<IWbemServices> pServices;
hResult = pLocator->ConnectServer(L"ROOT\\CimV2", nullptr, nullptr, nullptr, , nullptr, nullptr, &pServices);
if (!FAILED(hResult))
{
IEnumWbemClassObject* pClassObject = NULL;
//ATL::CComPtr<IEnumWbemClassObject> pClassObject;
hResult = pServices->CreateInstanceEnum(L"Win32_SerialPort", WBEM_FLAG_RETURN_IMMEDIATELY | WBEM_FLAG_FORWARD_ONLY | WBEM_FLAG_RETURN_WBEM_COMPLETE, nullptr, &pClassObject);
if (!FAILED(hResult))
{
hResult = WBEM_S_NO_ERROR;
while (WBEM_S_NO_ERROR == hResult)
{
unsigned long nReturned;
IWbemClassObject* pArrClassObject;
//ATL::CComPtr<IWbemClassObject> pArrClassObject[10];
//hResult = pClassObject->Next(WBEM_INFINITE, 10, reinterpret_cast<IWbemClassObject**>(pArrClassObject), &nReturned);
hResult = pClassObject->Next(WBEM_INFINITE, , &(pArrClassObject), &nReturned);
//hResult = 0x80041003
if (SUCCEEDED(hResult))
{
for (unsigned long i = ; i < nReturned; i++)
{
VARIANT stVariant;
HRESULT hGet = pArrClassObject->Get(L"DeviceID", , &stVariant, nullptr, nullptr);
if (SUCCEEDED(hGet) && stVariant.vt == VT_BSTR)
{
/*std::string item = stVariant.bstrVal;
if (0 == item.compare(0, 3, "COM"))*/
std::cout << stVariant.bstrVal << std::endl;
}
VariantClear(&stVariant);
pArrClassObject->Release();
}
}
}
pClassObject->Release();
}
pServices->Release();
}
pLocator->Release();
}
}
CoUninitialize();
} //5. //test: win7 no results
std::cout << "M5: ComDBGetCurrentPortUsage " << std::endl;
HCOMDB hComDB = nullptr;
if (ERROR_SUCCESS == ComDBOpen(&hComDB))
{
unsigned long nComDBBufferSize = ;
if (ERROR_SUCCESS == ComDBGetCurrentPortUsage(hComDB, nullptr, , CDB_REPORT_BYTES, &nComDBBufferSize))
{
unsigned char* szComDBBuffer = new unsigned char[nComDBBufferSize]();
if (ERROR_SUCCESS == ComDBGetCurrentPortUsage(hComDB, szComDBBuffer, nComDBBufferSize, CDB_REPORT_BYTES, &nComDBBufferSize))
{
for (size_t i = ; i < nComDBBufferSize; i++)
{
/* std::string item = szComDBBuffer;
if (0 == item.compare(0, 3, "COM"))*/
std::cout << szComDBBuffer << std::endl;
}
}
delete[] szComDBBuffer;
}
ComDBClose(hComDB);
} //4. //test: win7 no results
std::cout << "M4: EnumPorts " << std::endl;
unsigned long nNeeded = , nPortsSize = ;
if (!EnumPorts(nullptr, , nullptr, , &nNeeded, &nPortsSize))
{
unsigned long nError = GetLastError();
if (RPC_S_SERVER_UNAVAILABLE == nError)
std::cout << "SERVER_UNAVAILABLE" << std::endl;
else
std::cout << "Unknown Error " << nError << std::endl;
}
else
{
unsigned char* szEnumPortsBuffer = new unsigned char[nNeeded]();
if (EnumPorts(nullptr, , szEnumPortsBuffer, nNeeded, &nNeeded, &nPortsSize))
{
PORT_INFO_2* pPortInfo2 = reinterpret_cast<PORT_INFO_2*>(szEnumPortsBuffer);
for (size_t i = ; i < nPortsSize; i++)
{
std::string item = pPortInfo2->pPortName;
if ( == item.compare(, , "COM"))
std::cout << item << std::endl;
}
}
delete[] szEnumPortsBuffer;
} //3.
std::cout << "M3: QueryDosDevice " << std::endl;
unsigned long nResultLength = ;
unsigned long nBufferLengthTemp = ;
char* szpBuffer = new char[nBufferLengthTemp]();
do
{
nResultLength = QueryDosDevice(nullptr, szpBuffer, nBufferLengthTemp);
if ( == nResultLength && ERROR_INSUFFICIENT_BUFFER == GetLastError())
{
delete[] szpBuffer;
nBufferLengthTemp *= ;
szpBuffer = new char[nBufferLengthTemp]();
continue;
}
break;
} while (true);
char* szpBufferMovable = szpBuffer;
do
{
std::string item = szpBufferMovable;
if ( == item.compare(, , "COM"))
std::cout << item << std::endl; nResultLength -= (item.length() + );
szpBufferMovable += (item.length() + );
} while ( < nResultLength);
delete[] szpBuffer; //2.
std::cout << "M2: RegQueryValue " << std::endl;
ATL::CRegKey RegKey;
if (ERROR_SUCCESS == RegKey.Open(HKEY_LOCAL_MACHINE, "HARDWARE\\DEVICEMAP\\SERIALCOMM", KEY_QUERY_VALUE))
{
unsigned long nIndex = ;
while (true)
{
char szPorts[] = { };
unsigned long nPorts = sizeof(szPorts);
//一般为 ERROR_ACCESS_DENIED == 5
//if (ERROR_SUCCESS == RegKey.EnumKey(nIndex++, szPorts, &nPorts))
if (ERROR_SUCCESS == RegEnumValue(RegKey, nIndex++, szPorts, &nPorts, nullptr, nullptr, nullptr, nullptr))
{
char szPortsValue[] = { };
unsigned long nPortsValue = sizeof(szPortsValue);
if (ERROR_SUCCESS == RegKey.QueryStringValue(szPorts, szPortsValue, &nPortsValue))
{
std::cout << szPortsValue << std::endl;
continue;
}
}
break;
}
RegKey.Close();
} //1.
std::cout << "M1: CreateFile " << std::endl;
for (size_t i = ; i < ; i++)
{
char szPorts[] = { };
sprintf(szPorts, "\\\\.\\COM%d", i);
HANDLE hPorts = CreateFile(szPorts, GENERIC_READ | GENERIC_WRITE, , , OPEN_EXISTING, , );
if (INVALID_HANDLE_VALUE != hPorts)
{
std::cout << szPorts << std::endl;
CloseHandle(hPorts);
}
}

相关头文件库

using namespace std;
#include <string>
#include <vector>
#include <iostream>
#include <Windows.h>
#include <atlbase.h> //ATL::CRegKey
#include <winspool.h> //EnumPorts
#include <msports.h> //ComDBOpen
#pragma comment(lib, "msports.lib")
#include <WbemCli.h> //CLSID_WbemLocator
#pragma comment(lib, "WbemUuid.lib")
#include <setupapi.h> //SetupDiGetClassDevs

C++多种方法枚举串口号的更多相关文章

  1. 通过串口设备vid,pid自动获得该设备所对应的串口号

    用C#做串口通讯很方便,因为dotfx2.0已经集成了Serial Port控件,此控件使用上比MSComm控件更简单,当然它也有一个小bug (RecievedBytesThreshold设置有时候 ...

  2. CSS导航菜单水平居中的多种方法

    CSS导航菜单水平居中的多种方法 在网页设计中,水平导航菜单使用是十分广泛的,在CSS样式中,我们一般会用Float元素或是「display:inline-block」来解决.而今天主要讲解如何让未知 ...

  3. 用 Python 排序数据的多种方法

    用 Python 排序数据的多种方法 目录 [Python HOWTOs系列]排序 Python 列表有内置就地排序的方法 list.sort(),此外还有一个内置的 sorted() 函数将一个可迭 ...

  4. js判断移动端是否安装某款app的多种方法

    本文实例讲解了js判断移动端是否安装某款app的多种方法,分享给大家供大家参考,具体内容如下 第一种方法: 一:判断是那种设备 ? || u.indexOf(; //android终端或者uc浏览器 ...

  5. Gradle学习系列之二——创建Task的多种方法

    在本系列的上篇文章中,我们讲到了Gradle入门,在本篇文章中我们将讲到创建Task的多种方法. 请通过以下方式下载本系列文章的Github示例代码: git clone https://github ...

  6. SQL语句的添加、删除、修改多种方法

    SQL语句的添加.删除.修改虽然有如下很多种方法,但在使用过程中还是不够用,不知是否有高手把更多灵活的使用方法贡献出来? 添加.删除.修改使用db.Execute(Sql)命令执行操作╔------- ...

  7. 给ul中的li添加事件的多种方法

    给ul中的li添加事件的多种方法 这是一个常见,而且典型的前端面试题 <ul> <li>11111</li> <li>22222</li> ...

  8. PHP获取时间日期的多种方法

    分享下PHP获取时间日期的多种方法. <?php echo "今天:".date("Y-m-d")."<br>";     ...

  9. 转载“启动\关闭Oracle数据库的多种方法”--来自百度#Oracle

    启动\关闭Oracle数据库的多种方法 启动和关闭oracle有很多种方法. 这里只给出3种方法: l         Sql*plus l         OEM控制台 l         Wind ...

随机推荐

  1. Java实现 LeetCode 518 零钱兑换 II

    518. 零钱兑换 II 给定不同面额的硬币和一个总金额.写出函数来计算可以凑成总金额的硬币组合数.假设每一种面额的硬币有无限个. 示例 1: 输入: amount = 5, coins = [1, ...

  2. Java实现 蓝桥杯VIP 算法提高 P0402

    算法提高 P0402 时间限制:1.0s 内存限制:256.0MB 猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个.第二天早上又将剩下的桃子吃掉一半,又多吃了一个.以后每天早上都吃了前 ...

  3. Java实现 LeetCode 38 外观数列

    38. 外观数列 「外观数列」是一个整数序列,从数字 1 开始,序列中的每一项都是对前一项的描述.前五项如下: 1 11 21 1211 111221 1 被读作 "one 1" ...

  4. linux性能监控工具nmon生成HTML报告-EasyNmon

    一.关于easyNmon说明 为了方便多场景批量性能测试,用golang写了个监控程序,可以通过get url方式启动和停止nmon服务,非常适合配合Loadrunner性能测试框架和jmeter使用 ...

  5. KVM在线扩展虚拟机内存

    环境介绍 在KVM下有一台虚拟机内存不够需要扩展内存.宿主机地址是192.168.1.28.我需要扩展的虚拟机是centos1708vm03. 1.登陆上宿主机查看虚拟机配置 virsh dumpxm ...

  6. JDK8在泛型类型推导上的变化

    概述 JDK8升级,大部分问题可能在编译期就碰到了,但是有些时候比较蛋疼,编译期没有出现问题,但是在运行期就出了问题,比如今天要说的这个话题,所以大家再升级的时候还是要多测测再上线,当然JDK8给我们 ...

  7. IE6 中png背景透明的最好方法

    应用方式:(网站尾部加上如下代码) <!--[if IE 6]> <script src="js/DDPngMin.js"></script> ...

  8. 震惊!ConcurrentHashMap里面也有死循环,作者留下的“彩蛋”了解一下?

    JDK BUG 这篇文章,聊一下我最近才知道的一个关于 JDK 8 的 BUG 吧. 首先说一下我是怎么发现这个 BUG 的呢? 大家都知道我对 Dubbo 有一定的关注,前段时间 Dubbo 2.7 ...

  9. C++中为什么按两次ctrl+D才能结束标准I/O

    参考资料: https://www.douban.com/group/topic/127062773/ 今天学习了C++语言的标准I/O,也就是std::cin和std::cout,但是我发现当系统在 ...

  10. 使用ansible实现批量免密认证

    一.目的 批量实现免密认证,适合管理大批量机器使用 二.步骤 1-1.第一种方式:收集被控制主机的公钥,用于构建并验证ssh_known_hosts # ssh-keyscan 10.246.151. ...