C++ 获得cpu个数

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

               

本文转自:http://www.cppblog.com/Chipset/archive/2009/02/20/74403.html

 

  1. //测试CPU核心个数  
  2. #if !defined (_WIN32) && !defined (_WIN64)  
  3. #define LINUX  
  4. #include <sysconf.h>  
  5. #else  
  6. #define WINDOWS  
  7. #include <windows.h>  
  8. #endif  
  9. unsigned core_count()  
  10. {  
  11.   unsigned count = 1; // 至少一个  
  12.   #if defined (LINUX)  
  13.   count = sysconf(_SC_NPROCESSORS_CONF);  
  14.   #elif defined (WINDOWS)  
  15.   SYSTEM_INFO si;  
  16.   GetSystemInfo(&si);  
  17.   count = si.dwNumberOfProcessors;  
  18.   #endif  
  19.   return count;  
  20. }  
  21. #include <iostream>  
  22. int main()  
  23. {  
  24.   unsigned sz = core_count();  
  25.   std::cout << sz << (1 == sz ? "core" : "cores") << '/n';  
  26. }  
//测试CPU核心个数#if !defined (_WIN32) && !defined (_WIN64)#define LINUX#include <sysconf.h>#else#define WINDOWS#include <windows.h>#endifunsigned core_count(){  unsigned count = 1; // 至少一个  #if defined (LINUX)  count = sysconf(_SC_NPROCESSORS_CONF);  #elif defined (WINDOWS)  SYSTEM_INFO si;  GetSystemInfo(&si);  count = si.dwNumberOfProcessors;  #endif  return count;}#include <iostream>int main(){  unsigned sz = core_count();  std::cout << sz << (1 == sz ? "core" : "cores") << '/n';} 

           

给我老师的人工智能教程打call!http://blog.csdn.net/jiangjunshow
这里写图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
#include "StdAfx.h" #include "cpuassembly.h" // bit flags set by cpuid when called with register eax set to 1 #define MMX_SUPPORTED 0x00800000 #define SSE_SUPPORTED 0x02000000 #define SSE2_SUPPORTED 0x04000000 #define AMD_3DNOW_SUPPORTED 0x80000000 // AMD specific #define AMD_3DNOW_EX_SUPPORTED 0x40000000 #define AMD_MMX_EX_SUPPORTED 0x00400000 #define SUPPORT_MMX 0x0001 #define SUPPORT_3DNOW 0x0002 #define SUPPORT_SSE 0x0004 #define SUPPORT_SSE2 0x0008 CPUAssembly::CPUAssembly(void) { memset(&sCPUInfo, 0, sizeof(sCPUInfo)); } CPUAssembly::~CPUAssembly(void) { } bool CPUAssembly::IsCPUID() const { __try { _asm { xor eax, eax cpuid } } __except (EXCEPTION_EXECUTE_HANDLER) { return false; } return true; } bool CPUAssembly::QueryCPUInfo() { if (!IsCPUID()) return false; memset(&sCPUInfo, 0, sizeof(sCPUInfo)); DWORD dwStandard = 0; DWORD dwFeature = 0; DWORD dwMax = 0; DWORD dwExt = 0; int feature = 0; int os_support = 0; union { char cBuffer[12+1]; struct { DWORD dw0; DWORD dw1; DWORD dw2; } stc; } Vendor; memset(&Vendor, 0, sizeof(Vendor)); _asm { push ebx push ecx push edx // get the vendor string xor eax, eax cpuid mov dwMax, eax mov Vendor.stc.dw0, ebx mov Vendor.stc.dw1, edx mov Vendor.stc.dw2, ecx // get the Standard bits mov eax, 1 cpuid mov dwStandard, eax mov dwFeature, edx // get AMD-specials mov eax, 80000000h cpuid cmp eax, 80000000h jc notamd mov eax, 80000001h cpuid mov dwExt, edx notamd: pop ecx pop ebx pop edx } if (dwFeature & MMX_SUPPORTED) sCPUInfo.dwFeatures |= SUPPORT_MMX; if (dwExt & AMD_3DNOW_SUPPORTED) sCPUInfo.dwFeatures |= SUPPORT_3DNOW; if (dwFeature & SSE_SUPPORTED) sCPUInfo.dwFeatures |= SUPPORT_SSE; if (dwFeature & SSE2_SUPPORTED) sCPUInfo.dwFeatures |= SUPPORT_SSE2; sCPUInfo.iFamily = (short int)((dwStandard >> 8) & 0xF); // retrieve family if (sCPUInfo.iFamily == 15) // retrieve extended family sCPUInfo.iFamilyEx = (dwStandard >> 16) & 0xFF0; sCPUInfo.iModel = (short int)((dwStandard >> 4) & 0xF); // retrieve model if (sCPUInfo.iModel == 15) // retrieve extended model sCPUInfo.iModelEx = (dwStandard >> 12) & 0xF; sCPUInfo.iStepping = (short int)((dwStandard) & 0xF); // retrieve stepping strcpy(sCPUInfo.sVendorName, Vendor.cBuffer); sCPUInfo.iSpeed = ICPUInfo::GetSpeed(); strcpy(sCPUInfo.sProcessorName, ICPUInfo::GetCPUName(sCPUInfo.sVendorName, sCPUInfo.iFamily, sCPUInfo.iModel, sCPUInfo.iFamilyEx, sCPUInfo.iModelEx).c_str()); return true; } unsigned int CPUAssembly::GetSpeedMHz() const { return (unsigned int)(sCPUInfo.iSpeed/(1024*1024)); } std::string CPUAssembly::GetCPUName() const { return sCPUInfo.sProcessorName; } std::string CPUAssembly::GetVendorName() const { return sCPUInfo.sVendorName; } short int CPUAssembly::GetCPUFamily() const { return sCPUInfo.iFamily; } short int CPUAssembly::GetCPUModel() const { return sCPUInfo.iModel; } short int CPUAssembly::GetCPUStepping() const { return sCPUInfo.iStepping; } bool CPUAssembly::IsMMXSupported() const { return ((sCPUInfo.dwFeatures & SUPPORT_MMX) == SUPPORT_MMX); } bool CPUAssembly::IsSSESupported() const { return ((sCPUInfo.dwFeatures & SUPPORT_SSE) == SUPPORT_SSE); } bool CPUAssembly::IsSSE2Supported() const { return ((sCPUInfo.dwFeatures & SUPPORT_SSE2) == SUPPORT_SSE2); } bool CPUAssembly::Is3DNowSupported() const { return ((sCPUInfo.dwFeatures & SUPPORT_3DNOW) == SUPPORT_3DNOW); }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值