C++使用MFC獲取PC硬件配置信息
本文實(shí)例為大家分享了C++使用MFC獲取PC硬件配置信息的具體代碼,供大家參考,具體內(nèi)容如下
函數(shù)如下, 使用VS2010編譯通過(guò),在XP和Win7電腦上運(yùn)行過(guò),被注釋的loop 循環(huán)用于測(cè)試此方法是否穩(wěn)定:
//包含的頭文件:
#include "afxdialogex.h"
#include <windows.h>
#include <sstream>
#include <fstream>
void Cget_systemDlg::OnBnClickedButton1()
{
//for (int i = 0; i < 10000; i++) {
std::ostringstream osConfig;
osConfig.precision(1);
// Computer Name
TCHAR infoBuf[512] = {0};
DWORD bufCharCount = 512;
if (GetComputerName(infoBuf, &bufCharCount)) // MSDN: If the function succeeds, the return value is a nonzero value.
osConfig << "Computer Name: " << infoBuf << std::endl;
else
osConfig << "!Error: failed to get computer name" << std::endl;
// CPU
CString strPath = CString("HARDWARE\\DESCRIPTION\\System\\CentralProcessor\\0");
CRegKey regKey;
LONG lResult;
lResult = regKey.Open(HKEY_LOCAL_MACHINE, strPath, KEY_READ);
if (lResult == ERROR_SUCCESS)
{
TCHAR chCPUName[256] = {0};
DWORD dwSize = 256;
LPCSTR name = "ProcessorNameString";
regKey.QueryValue(chCPUName,_T("ProcessorNameString"),&dwSize);
osConfig << "CPU Type: " << (char*)chCPUName << std::endl;
regKey.Close();
}
else
osConfig << "!Error: failed to open register for read CPU." << std::endl;
// OS Name
char szOsType[MAX_PATH];
HKEY hKey;
LPCTSTR StrKey="Software\\Microsoft\\Windows NT\\CurrentVersion";
if (ERROR_SUCCESS == ::RegOpenKeyEx(HKEY_LOCAL_MACHINE,StrKey,NULL,KEY_READ,&hKey))
{
DWORD dwSize = 255;
DWORD dwType = REG_SZ;
LPCSTR KeyValue = "ProductName";
if (ERROR_SUCCESS == ::RegQueryValueEx(hKey,KeyValue,0,&dwType,(BYTE *)szOsType,&dwSize))
osConfig << "OS : " << szOsType;
else
osConfig << "!Error: failed to get OS name." << std::endl;
::RegCloseKey(hKey);
}
else
osConfig << "!Error: failed to get OS name." << std::endl;
SYSTEM_INFO si;
GetNativeSystemInfo(&si); // MSDN: This function does not return a value.
if (si.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_AMD64 || si.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_IA64 )
osConfig << " 64bits";
else
osConfig << " 32bits";
OSVERSIONINFO osVer;
osVer.dwOSVersionInfoSize = sizeof (OSVERSIONINFO);
if (::GetVersionEx (&osVer)) // MSDN: If the function succeeds, the return value is a nonzero value.
osConfig << " " << osVer.szCSDVersion << " " << std::endl;
else
osConfig << "!Error: failed to get OS CSD version.";
// Memory
MEMORYSTATUSEX statusex;
statusex.dwLength = sizeof (statusex);
if (GlobalMemoryStatusEx(&statusex)) // MSDN: If the function succeeds, the return value is nonzero.
{
osConfig << "Installed RAM: "<< std::fixed << statusex.ullTotalPhys /1024/1024/1024.0 << "GB";
osConfig << " Free RAM: " << std::fixed << statusex.ullAvailPhys/1024/1024/1024.0 << "GB" << std::endl;
}
else
osConfig << "!Error: failed to get RAM information." << std::endl;
// Hard Drive
// GetLogicalDriveStrings(sizeof(cDriveArray), cDriveArray);
// MSDN: If the function fails, the return value is zero.
// If the function succeeds, the return value is the length, in characters, of the strings copied to the buffer,
// not including the terminating null character
ULARGE_INTEGER free;
ULARGE_INTEGER total;
ULARGE_INTEGER totalfree;
TCHAR szDriveArray[128] = {0};
TCHAR *p, *pStart;
pStart = szDriveArray;
p = szDriveArray;
int nLen = GetLogicalDriveStrings(sizeof(szDriveArray), szDriveArray);
if (nLen !=0 )
{
while ((p = _tcschr(p, _T('\0'))) && p != szDriveArray + nLen )
{
if (GetDiskFreeSpaceEx(pStart, &free, &total, &totalfree)) // if success, nonzero
{
osConfig << "[" << pStart << "]" << " Total: " << std::fixed << total.QuadPart/1024/1024/1024.0
<< "GB Available: " << std::fixed << free.QuadPart/1024/1024/1024.0 << "GB";
if (GetDriveType(pStart) == 3)
osConfig <<" - Fixed Drive" << std::endl;
else if (GetDriveType(pStart) == 4)
osConfig <<" - (Remote Drive)" << std::endl;
else
osConfig <<" - Other" << std::endl;
}
pStart = ++p;
}
}
else
osConfig << "!Error: failed to get logical drive name." << std::endl;
AfxMessageBox(osConfig.str().c_str());
//std::ostringstream file;
//file << i << ".txt";
//std::ofstream log(file.str().c_str());
//log << osConfig.str().c_str();
//log.close();
//log.clear();
//}
AfxMessageBox("DONE");
}
輸出類(lèi)似如下的信息:
Computer Name: ATE CPU Type: Intel(R) Core(TM)2 Duo CPU E7500 @ 2.93GHz OS : Windows 7 Ultimate 64bits Service Pack 1 Installed RAM: 3.9GB Free RAM: 1.2GB [C:\] Total: 48.8GB Available: 13.4GB - Fixed Drive [D:\] Total: 100.0GB Available: 52.5GB - Fixed Drive [E:\] Total: 149.3GB Available: 7.2GB - Fixed Drive [K:\] Total: 4607.9GB Available: 230.9GB - (Remote Drive) [M:\] Total: 2000.0GB Available: 1703.8GB - (Remote Drive) [N:\] Total: 4607.9GB Available: 230.9GB - (Remote Drive) [P:\] Total: 4607.9GB Available: 230.9GB - (Remote Drive) [T:\] Total: 4607.9GB Available: 230.9GB - (Remote Drive) [X:\] Total: 142.8GB Available: 20.9GB - (Remote Drive)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Visual Studio 2019 DLL動(dòng)態(tài)庫(kù)連接實(shí)例(圖文教程)
這篇文章主要介紹了Visual Studio 2019 DLL動(dòng)態(tài)庫(kù)連接實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03
C++實(shí)現(xiàn)查找二叉樹(shù)中和為某一值的所有路徑的示例
這篇文章主要介紹了C++實(shí)現(xiàn)查找二叉樹(shù)中和為某一值的所有路徑的示例,文中的方法是根據(jù)數(shù)組生成二叉排序樹(shù)并進(jìn)行遍歷,需要的朋友可以參考下2016-02-02
詳解桶排序算法的思路及C++編程中的代碼實(shí)現(xiàn)
桶排序即是先把每個(gè)桶中的元素進(jìn)行排序然后遍歷桶依次列出元素的算法,桶排序在元素較少的情況下很高效,以下我們就來(lái)詳解桶排序算法的思路及C++編程中的代碼實(shí)現(xiàn):2016-07-07
C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
C++利用兩個(gè)棧實(shí)現(xiàn)隊(duì)列的方法
這篇文章主要給大家介紹了關(guān)于C++利用兩個(gè)棧實(shí)現(xiàn)隊(duì)列的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05

