C++如何获取系统信息 C++获取IP地址、硬件信息等

 更新时间:2019年04月26日 16:24:48   作者:lynch0571  
这篇文章主要为大家详细介绍了C++如何获取系统信,C++获取IP地址、硬件信息等,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C++获取系统信息的具体代码,供大家参考,具体内容如下

#include<stdio.h>
#include<winsock2.h> //该头文件需在windows.h之前
#include<windows.h>
#include<string>
#include<iostream>
#pragma comment(lib,"ws2_32.lib") 
using namespace std;
 
void getIP()
{
 WSADATA WSAData;  //WSADATA结构被用来储存调用AfxSocketInit全局函数返回的Windows Sockets初始化信息。
 if (WSAStartup(MAKEWORD(2, 0),&WSAData)) // 初始化Windows sockets API
 { 
 printf("WSAStartup failed %s\n", WSAGetLastError());
 exit(-1); //异常退出 
 } 
 
 char hostName[256];
 if(gethostname(hostName,sizeof(hostName))) //获取主机名
 {
 printf("Error: %u\n", WSAGetLastError());
 exit(-1); //异常退出 
 }
 printf("主机名:    %s\n", hostName);
 
 hostent *host=gethostbyname(hostName); // 根据主机名获取主机信息. 
 if(host==NULL)
 {
 printf("Error: %u\n", WSAGetLastError());
 exit(-1);
 }
 
 cout<<"主机地址类型:  "<<host->h_addrtype<<endl
 <<"地址清单:   "<<host->h_addr_list<<endl
 <<"别名列表:   "<<host->h_aliases<<endl
 <<"地址长度:   "<<host->h_length<<endl
 <<"正式的主机名:  "<<host->h_name<<endl;
 
 for(int i=0;host->h_addr_list[i]!=0;i++)
 {
 cout<<"该主机IP"<<i+1<<":   "<<inet_ntoa(*(struct in_addr*)*host->h_addr_list)<<endl;
 }
 cout<<"-----------------------------------------------"<<endl;
 WSACleanup(); 
}
void getSysInfo()
{
 SYSTEM_INFO sysInfo; //该结构体包含了当前计算机的信息:计算机的体系结构、中央处理器的类型、系统中中央处理器的数量、页面的大小以及其他信息。
 OSVERSIONINFOEX osvi;
 GetSystemInfo(&sysInfo);
 osvi.dwOSVersionInfoSize=sizeof(osvi);
 if (GetVersionEx((LPOSVERSIONINFOW)&osvi))
 {
 printf("操作系统版本 :  %u.%u.%u\n", osvi.dwMajorVersion, osvi.dwMinorVersion,osvi.dwBuildNumber);
 printf("Service Pack :  %u.%u\n", osvi.wServicePackMajor, osvi.wServicePackMinor);
 }
 printf("处理器架构 :  %u\n", sysInfo.wProcessorArchitecture);
 printf("处理器级别 :  %u\n", sysInfo.wProcessorLevel);
 printf("处理器版本 :  %u\n", sysInfo.wProcessorRevision);
 printf("处理器掩码 :  %u\n", sysInfo.dwActiveProcessorMask);
 printf("处理器数量 :  %u\n", sysInfo.dwNumberOfProcessors);
 printf("处理器类型 :  %u\n", sysInfo.dwProcessorType);
 printf("页面大小 :   %u\n", sysInfo.dwPageSize);
 printf("应用程序最小地址 : %u\n", sysInfo.lpMinimumApplicationAddress);
 printf("应用程序最大地址 : %u\n", sysInfo.lpMaximumApplicationAddress);
 printf("虚拟内存分配粒度 : %u\n", sysInfo.dwAllocationGranularity);
 printf("OemId :    %u\n", sysInfo.dwOemId);
 printf("wReserved :   %u\n", sysInfo.wReserved);
}
int main()
{
 getIP();
 getSysInfo();
 return 0; 
}

效果图

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C++中Boost.Chrono时间库的使用方法

    C++中Boost.Chrono时间库的使用方法

    chrono是一个time library, 源于boost,现在已经是C++11标准了,下面这篇文章主要给大家介绍了关于C++中Boost.Chrono时间库的使用方法,文中通过示例代码介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-09-09
  • 一文弄懂C语言EOF

    一文弄懂C语言EOF

    在 C语言中,EOF 是一个宏定义,EOF 常常用于文件的输入输出中,当读取到文件结束时,会返回 EOF,本文就详细的介绍一下具体使用方法,感兴趣的可以一起来了解一下
    2023-05-05
  • Mingw64编译wxWidgets 3.0.2常见错误分析

    Mingw64编译wxWidgets 3.0.2常见错误分析

    这篇文章主要介绍了Mingw64编译wxWidgets 3.0.2常见错误分析,需要的朋友可以参考下
    2016-11-11
  • C语言代码详细描述顺序线性表

    C语言代码详细描述顺序线性表

    这篇文章主要用代码介绍了C语言线性表的顺序线性表,对于学习数据结构与算法的朋友很有参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • C++图论之Bellman-Ford算法和SPFA算法的实现

    C++图论之Bellman-Ford算法和SPFA算法的实现

    贝尔曼-福特算法(Bellman-Ford)是由理查德·贝尔曼和莱斯特·福特创立的,求解单源最短路径问题的一种算法。SPFA 算法是 Bellman-Ford算法 的队列优化算法的别称,通常用于求含负权边的单源最短路径。本文将详解两个算法的实现,需要的可以参考一下
    2022-06-06
  • 深度剖析C++对象池自动回收技术实现

    深度剖析C++对象池自动回收技术实现

    今天小编就为大家分享一篇关于深度剖析C++对象池自动回收技术实现,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • C++空指针void*的使用方法

    C++空指针void*的使用方法

    C++空指针void是一种通用指针类型,可以指向任何类型的数据或对象。它不关心指向的数据或对象的类型,只关心指针本身的地址,在使用void指针时,需要将其转换为特定类型的指针,以便对其进行操作或访问其值,本文就给大家介绍一下C++空指针void的使用方法
    2023-06-06
  • C++实现并查集

    C++实现并查集

    这篇文章主要为大家详细介绍了C++实现并查集,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-07-07
  • Qt使用随机验证码的实现示例

    Qt使用随机验证码的实现示例

    有时候在登录界面需要验证码功能,这样能够防止被恶意程序攻击,本文主要介绍了Qt使用随机验证码的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • 解决C++中重定义的方法总结

    解决C++中重定义的方法总结

    本篇文章是对C++中重定义的解决方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05

最新评论