利用Qt實(shí)現(xiàn)獲取計(jì)算機(jī)的硬件信息
獲取的計(jì)算機(jī)信息包括:
1.計(jì)算機(jī)的名稱
2.所有的IP地址
3.計(jì)算機(jī)的當(dāng)前時(shí)間
4.CPU型號(hào)
5.顯卡型號(hào)(win10不兼容)
6.內(nèi)存大小
7.CPU的核數(shù)
10.獲得顯卡的內(nèi)存(win10不兼容)
#include <QtCore/QCoreApplication>
#include <Windows.h>
#include <QtCore\QTime>
#include <QtCore\qsettings.h>
#include <dxgi.h>
#include <QtNetwork\qhostinfo.h>
#include <QtCore\qthread.h>
//需要依賴dxgi.lib庫(kù)文件
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
//獲得計(jì)算機(jī)的名稱
QString hostName = QHostInfo::localHostName();
//獲得所有的IP地址
QHostInfo hostInfo = QHostInfo::fromName(QHostInfo::localHostName());
QList<QHostAddress> listAdress = hostInfo.addresses();
QStringList ipv4List;
for(int index=0; index<listAdress.size(); ++index)
{
if(listAdress.at(index).protocol() == QAbstractSocket::IPv4Protocol)
{
ipv4List.push_back(listAdress.at(index).toString());
}
}
//獲得計(jì)算機(jī)的當(dāng)前時(shí)間
QTime::currentTime().toString("hh::mm::ss");
//獲得CPU型號(hào)
QSettings* cpu = new QSettings("HKEY_LOCAL_MACHINE\\HARDWARE\\DESCRIPTION\\System\\CentralProcessor\\0", QSettings::NativeFormat);
QString cpuDescribe = cpu->value("ProcessorNameString").toString();
delete cpu;
//獲得顯卡型號(hào)(win10不兼容)
QSettings *videoCard = new QSettings("HKEY_LOCAL_MACHINE\\SYSTEM\\CurrentControlSet\\Services\\nvlddmkm\\Device0",QSettings::NativeFormat);
QString videoCardType = videoCard->value("Device Description").toString();
delete videoCard;
//獲得內(nèi)存大小
MEMORYSTATUSEX statex;
statex.dwLength = sizeof(statex);
GlobalMemoryStatusEx(&statex);
unsigned long memory_size = statex.ullTotalPhys;
int memory_size_MB = static_cast<double>(statex.ullTotalPhys)/static_cast<double>(1024*1024);
//獲得CPU的核數(shù)
QThread::idealThreadCount();
//獲得顯卡的內(nèi)存(win10不兼容)
IDXGIFactory* pFactory;
IDXGIAdapter* pAdapter;
std::vector<IDXGIAdapter*> vAdapters;
unsigned int total_Memory = 0;
int iAdapterNum = 0;
HRESULT hr = CreateDXGIFactory(__uuidof(IDXGIFactory),(void**)(&pFactory));
if(FAILED(hr)) return -1;
while(pFactory->EnumAdapters(iAdapterNum, &pAdapter) != DXGI_ERROR_NOT_FOUND)
{
vAdapters.push_back(pAdapter);
++iAdapterNum;
}
for(size_t i = 0; i<vAdapters.size(); ++i)
{
DXGI_ADAPTER_DESC adpterDesc;
vAdapters[i]->GetDesc(&adpterDesc);
total_Memory += adpterDesc.SharedSystemMemory;
}
int destInfo = total_Memory /1024/1024;
return a.exec();
}補(bǔ)充
當(dāng)然利用QT還可以獲取一些其他信息,下面是小編為大家整理的一些方法,需要的可以參考一下
獲取MAC地址
// 獲取MAC地址
QString Registration::GetMac()
{
// 獲取所有網(wǎng)絡(luò)接口列表
QList<QNetworkInterface> nets = QNetworkInterface::allInterfaces();
// 遍歷接口
int nCnt = nets.count();
QString strMacAddr = "";
for(int i = 0; i < nCnt; i++)
{
// 網(wǎng)絡(luò)接口需被激活且正在運(yùn)行且不是回環(huán)地址,才可能是要找的地址
if(nets[i].flags().testFlag(QNetworkInterface::IsUp) &&
nets[i].flags().testFlag(QNetworkInterface::IsRunning) &&
!nets[i].flags().testFlag(QNetworkInterface::IsLoopBack))
{
// 該mac的ip地址不能是回環(huán)地址并且是ipv4地址
for(int j = 0; j < nets[i].addressEntries().size(); j++)
{
if(nets[i].addressEntries().at(j).ip() != QHostAddress::LocalHost &&
nets[i].addressEntries().at(j).ip().protocol() == QAbstractSocket::IPv4Protocol)
{
strMacAddr = nets[i].hardwareAddress();
}
}
}
}
return strMacAddr;
}獲取處理器ID
通過(guò)wmic指令獲取。
// 獲取CPU處理器ID
QString Registration::GetCPUProcessorid()
{
QString cmd = QString("wmic cpu get processorid");
return GetWMICInfo(cmd);
}獲取主板序列號(hào)
通過(guò)wmic指令獲取。
// 獲取主板序列號(hào)
QString Registration::GetBaseboardSerialnumber()
{
QString cmd = QString("wmic baseboard get serialnumber");
return GetWMICInfo(cmd);
}
獲取BIOS序列號(hào)
通過(guò)wmic指令獲取。
// 獲取BIOS序列號(hào)
QString Registration::GetBIOSSerialnumber()
{
QString cmd = QString("wmic bios get serialnumber");
return GetWMICInfo(cmd);
}
到此這篇關(guān)于利用Qt實(shí)現(xiàn)獲取計(jì)算機(jī)的硬件信息的文章就介紹到這了,更多相關(guān)Qt獲取計(jì)算機(jī)硬件信息內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++計(jì)算任意兩個(gè)日期天數(shù)差的方法詳解
這篇文章主要為大家詳細(xì)介紹了如何利用C++實(shí)現(xiàn)任意兩個(gè)日期天數(shù)差,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,有需要的小伙伴可以參考一下2024-02-02
數(shù)據(jù)結(jié)構(gòu) 中數(shù)制轉(zhuǎn)換(棧的應(yīng)用)
這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu) 中數(shù)制轉(zhuǎn)換(棧的應(yīng)用)的相關(guān)資料,需要的朋友可以參考下2017-06-06
C語(yǔ)言自定義函數(shù)的實(shí)現(xiàn)
這篇文章主要介紹了C語(yǔ)言自定義函數(shù)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
C語(yǔ)言實(shí)現(xiàn)小貓釣魚(yú)游戲
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)小貓釣魚(yú)游戲,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01
C++?BoostAsyncSocket實(shí)現(xiàn)異步反彈通信的案例詳解
這篇文章主要為大家詳細(xì)介紹了C++?BoostAsyncSocket如何實(shí)現(xiàn)異步反彈通信,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的可以了解一下2023-03-03
哈希表實(shí)驗(yàn)C語(yǔ)言版實(shí)現(xiàn)
以下是對(duì)哈希表實(shí)驗(yàn)用C語(yǔ)言實(shí)現(xiàn)的代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以參考下2013-07-07
基于OpenCV實(shí)現(xiàn)車道線檢測(cè)(自動(dòng)駕駛 機(jī)器視覺(jué))
無(wú)人駕駛技術(shù)是機(jī)器學(xué)習(xí)為主的一門前沿領(lǐng)域,在無(wú)人駕駛領(lǐng)域中機(jī)器學(xué)習(xí)的各種算法隨處可見(jiàn),本文將為大家介紹無(wú)人駕駛技術(shù)中的車道線檢測(cè),感興趣的小伙伴可以了解一下2021-11-11
錯(cuò)誤:sem_union的存儲(chǔ)大小未知問(wèn)題的解決方法
這篇文章主要介紹了錯(cuò)誤:sem_union的存儲(chǔ)大小未知問(wèn)題的解決方法,需要的朋友可以參考下2016-10-10

