---------------------------------------------------------------------------
VC 驿站
WwW.CcTry.CoM
多抽出一分钟时间来学习,让你的生命更加精彩!
C、C++、VC++ 各种学习资源,免费教程,期待您的加入!
动画教程只是起到技术交流的作用,请大家不用利用此方法做非法用途.
由此动画造成的任何后果和动画作者及本站无关.
----------------------------------------------------------------------------------------
大家好,我是Syc
今天给大家做的教程是:
vc++基础班[25]---系统信息的获取
------------------------------------------ Begin ----------------------------------------
 
①、获取当前登录用户名称:
函数为:GetUserName,准确的说此函数为获取当前线程关联的用户名称;
 
②、获取计算机名称:
函数为:GetComputerName,当然也可以通过 SetComputerName 函数来进行计算机名称的设置,但必须重新启动系统!
 
③、获取CPU的描述信息:
CString GetCpuDescription()
{
 CString strCPU;
 HKEY hKey = NULL;
 LONG lRet = RegOpenKeyEx(HKEY_LOCAL_MACHINE,
  _T("Hardware\\Description\\System\\CentralProcessor\\0") , 0, KEY_QUERY_VALUE, &hKey);
 if(lRet == ERROR_SUCCESS){
  DWORD dwSize = 0;
  BYTE *pszBuf = NULL;
  lRet = RegQueryValueEx(hKey, _T("ProcessorNameString"), NULL, NULL, NULL, &dwSize);
  if(lRet == ERROR_SUCCESS && dwSize > 0){
   pszBuf = new BYTE[dwSize+1];
   ZeroMemory(pszBuf, dwSize+1);
   RegQueryValueEx(hKey, _T("ProcessorNameString"), NULL, NULL, pszBuf, &dwSize);
  }
  RegCloseKey(hKey);
  strCPU.Format(_T("%s"), pszBuf);
  if (pszBuf) delete [] pszBuf;
 }
 return strCPU;
}
 
④、获取内存信息:
ULONGLONG GetMemoryInfo()
{
 ULONGLONG dwMemSpace = 0;
 MEMORYSTATUSEX memStatus = {0};
 memStatus.dwLength = sizeof(MEMORYSTATUSEX);
 GlobalMemoryStatusEx(&memStatus);
 dwMemSpace = (ULONGLONG)(memStatus.ullTotalPhys /1024/1024);
 return dwMemSpace;
}
 
⑤、获取磁盘列表及容量信息:
计算机存储单位:Byte、KB、MB、GB、TB、PB、EB、ZB、YB、DB、NB
////////////////////////////////////////////////////////////////////////////////
CString EnumDrives()
{
 UINT nCount = 0;
 CString strDrives;
 TCHAR *pBuf = NULL;
 //原则上来说 4*26+1 大小就够用了,每个盘符占用4个字符,也就是:C:\\0
 TCHAR szBuf[MAX_PATH] = {0};
 DWORD dwRet = GetLogicalDriveStrings(MAX_PATH, szBuf);
 if (dwRet != 0){
  nCount = dwRet/4;
  pBuf = szBuf;
  for (UINT idx = 0; idx < nCount; ++idx, pBuf += 4){
   strDrives.AppendFormat(_T("%s%s"), pBuf, _T("\r\n"));
  }
 }
 return strDrives;
}
 
CString GetDriveTypeString(CString strDrive)
{
 //传递的参数至少要包含:盘符+ :
 //也可以是目录的路径,但是结尾必须有\\符号
 CString strDriveTpye;
 UINT uType = GetDriveType(strDrive);
 switch (uType)
 {
 case DRIVE_UNKNOWN:
  strDriveTpye = _T("类型未知!");
  break;
 case DRIVE_NO_ROOT_DIR:
  strDriveTpye = _T("指定的盘符不存在!");
  break;
 case DRIVE_REMOVABLE:
  strDriveTpye = _T("软盘或U盘");
  break;
 case DRIVE_FIXED:
  strDriveTpye = _T("本地硬盘或移动硬盘");
  break;
 case DRIVE_REMOTE:
  strDriveTpye = _T("网络磁盘");
  break;
 case DRIVE_CDROM:
  strDriveTpye = _T("CD-ROM");
  break;
 case DRIVE_RAMDISK:
  strDriveTpye = _T("RAM 磁盘");
  break;
 default:
  break;
 }
 return strDriveTpye;
}
 
CString GetDriveSpaceInfo(CString strDrive)
{
 CString strInfo;
 ULARGE_INTEGER nFreeBytesAvailable = {0};
 ULARGE_INTEGER nTotalNumberOfBytes = {0};
 ULARGE_INTEGER nTotalNumberOfFreeBytes = {0};
 
 if (GetDiskFreeSpaceEx(strDrive, &nFreeBytesAvailable, &nTotalNumberOfBytes, &nTotalNumberOfFreeBytes)) {
  //单位是字节
  //strInfo.Format(_T("可用容量:%I64u Byte\r\n总容量:%I64u Byte\r\n所有可用容量:%I64u Byte"),
  // nFreeBytesAvailable.QuadPart, nTotalNumberOfBytes.QuadPart, nTotalNumberOfFreeBytes.QuadPart);
 
  //单位是GB
  long double dFreeBytesAvailable = ((long double)(nFreeBytesAvailable.QuadPart))/(1024*1024*1024);
  long double dTotalNumberOfBytes = ((long double)(nTotalNumberOfBytes.QuadPart))/(1024*1024*1024);
  long double dTotalNumberOfFreeBytes = ((long double)(nTotalNumberOfFreeBytes.QuadPart))/(1024*1024*1024);
 
  strInfo.Format(_T("可用容量:%.2Lf GB\r\n总容量:%.2Lf GB\r\n所有可用容量:%.2Lf GB"),
   dFreeBytesAvailable, dTotalNumberOfBytes, dTotalNumberOfFreeBytes);
 }
 
 return strInfo;
}
 

vc++基础班[25]---系统信息的获取的更多相关文章

  1. vc++基础班[24]---系统各种路径信息的获取

    vc++基础班[24]---系统各种路径信息的获取 ------------------------------------------ Begin ------------------------- ...

  2. vc++基础班[23]---文件夹的基本操作

      ①.文件夹的创建:CreateDirectory ※※※ 注意:此函数只能创建一层目录,比如想在 C 盘下的 Temp 目录下创建新目录为:123 那么前提是 Temp 这个目录存在才可以!   ...

  3. vc++基础班[22]---文件的基本操作2

      MFC 中的 CFile 及其派生类中没有提供直接进行文件的复制操作,因而要借助于SDK API: SDK中的文件相关函数常用的有CopyFile().CreateDirectory().Dele ...

  4. vc++基础班[27]---实现一个简单的任务管理器

      因为任务管理器中涉及到进程的枚举操作,所以把两节课的知识点合并到一起来讲!   ①.设计界面.以及列表控件变量的绑定: ②.列表控件样式的指定: m_TaskList.SetExtendedSty ...

  5. vc++基础班[28]---动态数组及动态链表的讲解

    C++中也有相应的动态数组.动态链表.映射表的模板类,就是STL中的:vector.list.map 他们属于C++标准中的一部分,对于程序的移植性来说也是不错的,但是在MFC编程中使用 CArray ...

  6. vc++基础班[21]---文件的基本操作之CFile

    ①.文件的创建.打开.关闭: 文件的创建.打开:CFile::Open 文件的关闭:CFile::Close   CFile::modeCreate:以新建方式打开,如果文件不存在,则新建:如果文件已 ...

  7. vc++基础班[26]---进程的相关操作

      ①.ShellExecute 进行进程的创建,属于 shell api: //int iRet = (int)ShellExecute(m_hWnd, _T("open"), ...

  8. Python基础班学习笔记

    本博客采用思维导图式笔记,所有思维导图均为本人亲手所画.因为本人也是初次学习Python语言所以有些知识点可能不太全. 基础班第一天学习笔记:链接 基础班第二天学习笔记:链接 基础班第三天学习笔记:链 ...

  9. 老段带你学鸟哥Linux视频教程 包含基础班+提高班

    老段带你学鸟哥Linux视频教程 包含基础班+提高班,附带pdf文档. 目录结构如下: 目录:/-老段带你学鸟哥Linux视频教程 [.9G] ┣━━老段带你学鸟哥-服务器篇 [1009.4M] ┃ ...

随机推荐

  1. keytool导入导出多条目对比【原】

    步骤一:生成orange.keystore和banana.keystore keytool -genkey -alias orange -keyalg RSA -keysize 1024 -keypa ...

  2. Nginx+Tomcat+Https 服务器负载均衡配置

    这篇过气了! 重新补一个:http://www.cnblogs.com/hackyo/p/6809773.html 由于需要,得搭建个nginx+tomcat+https的服务器,搜了搜网上的发现总是 ...

  3. Good, then we can start

  4. HttpService

    // // Source code recreated from a .class file by IntelliJ IDEA // (powered by Fernflower decompiler ...

  5. MySQL触发器实现表数据同步

    其中old表示tab2(被动触发),new表示tab1(主动触发,外部应用程序在此表里执行insert语句) 1.插入:在一个表里添加一条记录,另一个表也添加一条记录DROP TABLE IF EXI ...

  6. GCC编译器原理(二)------编译原理一:ELF文件(3)

    4.5 String Table:字符串表 字符串表节区包含以 NULL( ASCII 码 0) 结尾的字符序列, 通常称为字符串. ELF 目标文件通常使用字符串来表示符号和节区名称. 对字符串的引 ...

  7. 四、文件IO——内核数据结构和原子操作

    4.1 缓存 buff 说明 一般设置缓存 buff  的大小是由一定的规律的,就是根据磁盘块的大小来定. Linux下输入命令: df -k  查看磁盘 可以用命令查看下 /dev/sda1 磁盘的 ...

  8. Coursera, Deep Learning 1, Neural Networks and Deep Learning - week3, Neural Networks Basics

    NN representation 这一课主要是讲3层神经网络 下面是常见的 activation 函数.sigmoid, tanh, ReLU, leaky ReLU. Sigmoid 只用在输出0 ...

  9. luogu P3295 [SCOI2016]萌萌哒

    传送门 题目条件"两个子串\(S[l_1,r_1],S[l_2,r_2]\)完全相同"等价于\(\forall i \in[0,r_1-l_1+1],S_{l1+i}=S_{l_2 ...

  10. EcustOJ P109跳一跳(离散化+dp)

    题目链接 感觉这道题我看了很多天,胡思乱想啊,一开始觉得记忆化搜索会可能T啊,,可能出题人的数据卡的好就稳T了的感觉..后来想了想,好像离散化一下,记一下位置之后再记忆化搜索就应该稳了吧..(好像直接 ...