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

  //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实现第六届蓝桥杯灾后重建

    灾后重建 题目描述 Pear市一共有N(<=50000)个居民点,居民点之间有M(<=200000)条双向道路相连.这些居民点两两之间都可以通过双向道路到达.这种情况一直持续到最近,一次严 ...

  2. Mac上查看当前安卓手机上打开的app的包名和主程序入口

    1.连接上手机,数据线链接或者无线连接随便 2.打开你需要查看的app 3.打开终端,输入命令: adb shell dumpsys window w |grep \/ |grep name=

  3. centos7 yum源更新

    先进入到yum源文件cd /etc/yum.repo.d/  1.创建一个repo_bak目录,用于保存系统中原来yum的repo文件. sudo mkdir repo_bak 2.备份yum源文件至 ...

  4. 提高编译速度! 第一次运行需要注释掉,不然会报错,因为需要编译SO库文件 !

    // 提高编译速度! 第一次运行需要注释掉,不然会报错,因为需要编译SO库文件 ! tasks.whenTaskAdded { task -> if (task.name.contains(&q ...

  5. 来看看阿里架构师Java 代码打日志姿势!你也是这样写的吗

    使用slf4j 使用门面模式的日志框架,有利于维护和各个类的日志处理方式统一. 实现方式统一使用: Logback框架 打日志的正确方式 什么时候应该打日志 当你遇到问题的时候,只能通过debug功能 ...

  6. Spring Boot 教程 - Elasticsearch

    1. Elasticsearch简介 Elasticsearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口.Elasticsearc ...

  7. Nice Jquery Validator 自定义规则

    规则定义方式 (1). 正则 适用于使用单个正则能搞定的验证. // 使用数组包裹正则和错误消息,规则不通过时提示该消息 mobile: [/^1[3458]\d{9}$/, '请检查手机号格式'] ...

  8. Shell总结02-shell变量、赋值与替换

    变量 shell并不区分变量的类型,或者说变量都是弱类型的,本质上都是字符串,但是如果变量值中只含有数字,shell还是支持对其进行算术运算 赋值 常见的赋值操作符有=(在其前后没有空白符)和let ...

  9. pip环境变量配置

    找到python安装目录,进入C:\Users\EDZ\AppData\Local\Programs\Python\Python37-32\Scripts  下.添加此地址到path中 打开cmd 输 ...

  10. 附016.Kubernetes_v1.17.4高可用部署

    一 kubeadm介绍 1.1 概述 参考<附003.Kubeadm部署Kubernetes>. 1.2 kubeadm功能 参考<附003.Kubeadm部署Kubernetes& ...