C++多种方法枚举串口号
部分方式没结果,思路应该是没错。
//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++多种方法枚举串口号的更多相关文章
- 通过串口设备vid,pid自动获得该设备所对应的串口号
用C#做串口通讯很方便,因为dotfx2.0已经集成了Serial Port控件,此控件使用上比MSComm控件更简单,当然它也有一个小bug (RecievedBytesThreshold设置有时候 ...
- CSS导航菜单水平居中的多种方法
CSS导航菜单水平居中的多种方法 在网页设计中,水平导航菜单使用是十分广泛的,在CSS样式中,我们一般会用Float元素或是「display:inline-block」来解决.而今天主要讲解如何让未知 ...
- 用 Python 排序数据的多种方法
用 Python 排序数据的多种方法 目录 [Python HOWTOs系列]排序 Python 列表有内置就地排序的方法 list.sort(),此外还有一个内置的 sorted() 函数将一个可迭 ...
- js判断移动端是否安装某款app的多种方法
本文实例讲解了js判断移动端是否安装某款app的多种方法,分享给大家供大家参考,具体内容如下 第一种方法: 一:判断是那种设备 ? || u.indexOf(; //android终端或者uc浏览器 ...
- Gradle学习系列之二——创建Task的多种方法
在本系列的上篇文章中,我们讲到了Gradle入门,在本篇文章中我们将讲到创建Task的多种方法. 请通过以下方式下载本系列文章的Github示例代码: git clone https://github ...
- SQL语句的添加、删除、修改多种方法
SQL语句的添加.删除.修改虽然有如下很多种方法,但在使用过程中还是不够用,不知是否有高手把更多灵活的使用方法贡献出来? 添加.删除.修改使用db.Execute(Sql)命令执行操作╔------- ...
- 给ul中的li添加事件的多种方法
给ul中的li添加事件的多种方法 这是一个常见,而且典型的前端面试题 <ul> <li>11111</li> <li>22222</li> ...
- PHP获取时间日期的多种方法
分享下PHP获取时间日期的多种方法. <?php echo "今天:".date("Y-m-d")."<br>"; ...
- 转载“启动\关闭Oracle数据库的多种方法”--来自百度#Oracle
启动\关闭Oracle数据库的多种方法 启动和关闭oracle有很多种方法. 这里只给出3种方法: l Sql*plus l OEM控制台 l Wind ...
随机推荐
- Java实现蓝桥杯模拟元音单词的验证
问题描述 小明对类似于 hello 这种单词非常感兴趣,这种单词可以正好分为四段,第一段由一个或多个辅音字母组成,第二段由一个或多个元音字母组成,第三段由一个或多个辅音字母组成,第四段由一个或多个元音 ...
- java实现 洛谷 P1427 小鱼的数字游戏
题目描述 小鱼最近被要求参加一个数字游戏,要求它把看到的一串数字(长度不一定,以0结束,最多不超过100个,数字不超过2^32-1),记住了然后反着念出来(表示结束的数字0就不要念出来了).这对小鱼的 ...
- Linux 用户组管理命令
groupadd 组名,可以添加用户组 groupmod -n 新组名 老组名,可以修改组名 groupdel 组名,可以删除组(组中不能有初始用户存在,附加用户无所谓) gpasswd -a 用户名 ...
- PAT 说反话
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出. 输入格式: 测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串.字符串由若干单词和若干空格组成,其中单词是由英文字母(大小 ...
- tab-switch 样式的添加 与 tab元素样式的切换
要点: 1.多个div类名相同情况下添加class样式 2.siblings() 方法返回被选元素的所有同级元素.DOM 树:该方法沿着 DOM 元素的同级元素向前和向后遍历. 3.利用索引,只添加当 ...
- Layui 实现一个高级筛选功能
基于layui写的一个高级搜索(筛选)功能.效果图: 是一位萌新,所有写的有点儿乱.(放在上面,供新手们参考,也是自己做一个记录.)代码如下: <!DOCTYPE html PUBLIC &qu ...
- “进大厂大半年,每个月都想走!”大公司 VS 小公司到底该如何选择?
前言 江湖风云不断,有人吐槽阿里996,也有人吐槽华为狼性文化,这不,就看到有腾讯员工吐槽“进腾讯大半年,每个月都想走!” “和我一样,进去一周就想走”.“我都陷入自我怀疑了,以为自己适应不了大公司” ...
- vue踩过的坑('url' is assigned a value but never used no-unused-vars)
1.代码编写 2.遇见错误 3.解决方案 在错误代码后加入注释:(// eslint-disable-line no-unused-vars) 之后页面上就不会出现该错误信息了
- Error reporting for dbus
D-Bus 1.13.14 目录 Detailed Description Function Documentation ◆ dbus_error_free() ◆ dbus_error_has_na ...
- [转] 图解单片机下载程序电路原理之USB转串口线、CH340、PL2303、MAX232芯片的使用
点击阅读原文 目前为止,我接触单片机已有不少时日,从选择元器件.原理图.PCB.电路硬件调试.软件开发也算小有心得 .单片机软件开发里面第一步当属下载程序了,如果这一步都有问题,那么后面的一切便无从谈 ...