您好,登錄后才能下訂單哦!
原來C++Builder6在XP下獲取串口的方法:
void TTools::GetSystemPortList(TStringList * pList) { TRegistry *regkey=new TRegistry(); pList->Clear(); regkey->RootKey=HKEY_LOCAL_MACHINE; TStringList *KeyNames; KeyNames=new TStringList(); regkey->OpenKey("HARDWARE\\DEVICEMAP\\SERIALCOMM",false); regkey->GetValueNames(KeyNames); for(int i=0;i<=(KeyNames->Count-1);i++) { AnsiString a = regkey->ReadString(KeyNames->Strings[i]); pList->Add(a); } regkey->CloseKey(); delete KeyNames; delete regkey; }
這種方法,編譯好的程序,在Win10下無效,需要管理員權限執行才行.
在Win10直接用API讀注冊表獲取,代碼如下:
void TTools::GetSystemAllPort(TStringList * pList) { HKEY hKey; DWORD result; TCHAR valueName[255]; TCHAR data[255]; DWORD valueNameSize,dataSize; DWORD i; result = RegOpenKeyEx(HKEY_LOCAL_MACHINE, "Hardware\\DeviceMap\\SerialComm", NULL, KEY_READ, &hKey);//讀取注冊表串口信息 if(ERROR_SUCCESS == result) { for(i=0;i<256 ;i++) { valueNameSize = dataSize = sizeof(valueName) / sizeof(TCHAR); result = RegEnumValue(hKey, i, valueName, &valueNameSize, NULL, NULL, (LPBYTE)data, &dataSize); if(ERROR_NO_MORE_ITEMS == result ) { break; } else { pList->Add(data); } } } else { ::MessageBox(0,"PORT ERROR!","Error",0); } RegCloseKey(hKey); }
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。