Windows下获取逻辑cpu数量和cpu核数量(用GetLogicalProcessorInformation,从XP3才开始有的API)

代码可在Windows NT下正常运行

具体API说明请参照如下文档:

GetLogicalProcessorInformation

点击打开链接

点击打开链接

点击打开链接

[html] view plain copy

  1. typedef BOOL (WINAPI *LPFN_GLPI)(PSYSTEM_LOGICAL_PROCESSOR_INFORMATION, PDWORD);
  2. DWORD CountSetBits(ULONG_PTR bitMask)
  3. {
  4. DWORD LSHIFT = sizeof(ULONG_PTR)*8 - 1;
  5. DWORD bitSetCount = 0;
  6. ULONG_PTR bitTest = (ULONG_PTR)1 << LSHIFT;
  7. DWORD i;
  8. for (i = 0; i <= LSHIFT; ++i)
  9. {
  10. bitSetCount += ((bitMask & bitTest)?1:0);
  11. bitTest/=2;
  12. }
  13. return bitSetCount;
  14. }
  15. LPFN_GLPI glpi;
  16. glpi = (LPFN_GLPI) GetProcAddress(GetModuleHandle(TEXT("kernel32")),"GetLogicalProcessorInformation");
  17. if (NULL == glpi)
  18. {
  19. printf("GetLogicalProcessorInformation is not supported.\n");
  20. }
  21. BOOL done = FALSE;
  22. PSYSTEM_LOGICAL_PROCESSOR_INFORMATION buffer = NULL;
  23. PSYSTEM_LOGICAL_PROCESSOR_INFORMATION ptr = NULL;
  24. DWORD returnLength = 0;
  25. while (!done)
  26. {
  27. DWORD rc = glpi(buffer, &returnLength);
  28. if (FALSE == rc)
  29. {
  30. if (GetLastError() == ERROR_INSUFFICIENT_BUFFER)
  31. {
  32. if (buffer)
  33. free(buffer);
  34. buffer = (PSYSTEM_LOGICAL_PROCESSOR_INFORMATION)malloc(returnLength);
  35. if (NULL == buffer)
  36. {
  37. printf("Error: Allocation failure\n");
  38. return (2);
  39. }
  40. }
  41. else
  42. {
  43. printf("Error %d\n", GetLastError());
  44. return (3);
  45. }
  46. }
  47. else
  48. {
  49. done = TRUE;
  50. }
  51. }
  52. ptr = buffer;
  53. DWORD byteOffset = 0;
  54. DWORD logicalProcessorCount = 0;
  55. DWORD processorCoreCount = 0;
  56. while (byteOffset + sizeof(SYSTEM_LOGICAL_PROCESSOR_INFORMATION) <= returnLength)
  57. {
  58. switch (ptr->Relationship)
  59. {
  60. case RelationProcessorCore:
  61. processorCoreCount++;
  62. logicalProcessorCount += CountSetBits(ptr->ProcessorMask);
  63. break;
  64. }
  65. byteOffset += sizeof(SYSTEM_LOGICAL_PROCESSOR_INFORMATION);
  66. ptr++;
  67. }
  68. printf("logical:%d  core:%d\n", logicalProcessorCount, processorCoreCount);

http://blog.csdn.net/tobacco5648/article/details/22201169

时间: 2024-10-13 06:56:03

Windows下获取逻辑cpu数量和cpu核数量(用GetLogicalProcessorInformation,从XP3才开始有的API)的相关文章

windows 下获取当前进程的线程数量

#include <TlHelp32.h> int get_thread_amount() { int i = 0; char Buff[9]; PROCESSENTRY32 pe32; pe32.dwSize = sizeof(pe32); int processid = GetCurrentProcessId(); HANDLE hProcessSnap = ::CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0); if (hProcessSna

Windows下获取高精度时间注意事项

Windows下获取高精度时间注意事项 [转贴 AdamWu] 花了很长时间才得到的经验,与大家分享. 1. RDTSC - 粒度: 纳秒级 不推荐优势: 几乎是能够获得最细粒度的计数器抛弃理由: A) 定义模糊 - 曾经据说是处理器的cycle counter,但是后来似乎又不是了.有的机器上每秒的TSC增长值等于CPU频率,有的却是一个不对应任何配置的数.到底是什么,Intel也没解释清楚. B) 不准确 - 这是最重大的缺陷.再细的粒度,不准的话也没用,至少不能当时间用.在有的CPU上,特

c和c++在windows下获取时间和计算时间差的方法总结

c/c++在windows下获取时间和计算时间差的几种方法总结 一.标准C和C++都可用 1.获取时间用time_t time( time_t * timer ),计算时间差使用double difftime( time_t timer1, time_t timer0 ). 精确到秒. 测试程序如下: 1 #include <time.h> 2 #include <stdio.h> 3 4 int main() 5 { 6 time_t start, end; 7 double c

Windows下caffe安装详解(仅CPU)

本文大多转载自 http://blog.csdn.net/guoyk1990/article/details/52909864,加入部分自己实战心得. 1.环境:windows 7\VS2013 2.caffe-windows准备 (1)下载官方caffe-windows并解压,将 .\windows\CommonSettings.props.example备份,并改名为CommonSettings.props.如图4所示: 图 4:修改后的CommonSettings.props文件 附带说明

windows下揪出java程序占用cpu很高的线程 并找到问题代码 死循环线程代码

我的一个java程序偶尔会出现cpu占用很高的情况 一直不知道什么原因 今天终于抽时间解决了 系统是win2003 jvisualvm 和 jconsole貌似都只能看到总共占用的cpu 看不到每个线程分别占用的cpu呢 所以在windows平台上要找出到底是哪个线程占用的cpu还不那么容易,linux用top就简单多了 最后的解决方法: 1.找到java进程对应的pid. 找pid的方法是:打开任务管理器,然后点击 "查看" 菜单,然后点击 "选择列",把pid勾

windows下揪出java程序占用cpu很高的线程

1.找到java进程对应的pid.通过任务管理器.linux---top 2.然后把java进程导出快照.直接运行命令.stack -l 31372 > c:/31372.stack 3.在windows下只能查看进程的cpu占用率,要查看线程的cpu占用率要借助其他的工具,我这里用的是微软提供的 Process Explorer v15.3 右键点击需要查看的进程---properties linux下先输入top,然后再按shift+h 或"H",此时打开的是线程视图,pid

【转载】c/c++在windows下获取时间和计算时间差的几种方法总结

一.标准C和C++都可用 1.获取时间用time_t time( time_t * timer ),计算时间差使用double difftime( time_t timer1, time_t timer0 ). 精确到秒. 测试程序如下: #include <time.h> #include <stdio.h> int main() { time_t start ,end ; double cost; time(&start); sleep(1); time(&en

windows下获取硬盘信息的命令

2020-1-17windows下获取硬盘序列号===================================winkey run cmdMicrosoft Windows [版本 10.0.18363.592](c) 2019 Microsoft Corporation.保留所有权利.方法1:C:\Users\Administrator>wmic diskdrive get serialnumberSerialNumberW3PC29KQ 方法2:C:\Users\Administra

windows和linux下获取当前程序路径以及cpu数

[cpp] view plaincopy #ifdef WIN32 #include <Windows.h> #else #include <stdio.h> #include <unistd.h> #endif #include <assert.h> std::string getCurrentAppPath() { #ifdef WIN32 char path[MAX_PATH + 1] = {0}; if (GetModuleFileName(NULL