【Darwin学习笔记】之获取系统处理器数量的方法
阅读Darwin源码的时候看到这个方法,感觉挺有用处,且考虑了多种平台下的实现方式,直接贴代码,以后说不定会用到~
单一种平台下的实现方法可能很容易,但是把这些个系统都收集在一起,在一个函数中实现还是极好的
【转载请注明出处】:http://blog.csdn.net/longlong530
- UInt32 OS::GetNumProcessors()
- {
- #if (__Win32__)
- SYSTEM_INFO theSystemInfo;
- ::GetSystemInfo(&theSystemInfo);
- return (UInt32)theSystemInfo.dwNumberOfProcessors;
- #endif
- #if (__MacOSX__ || __FreeBSD__)
- int numCPUs = 1;
- size_t len = sizeof(numCPUs);
- int mib[2];
- mib[0] = CTL_HW;
- mib[1] = HW_NCPU;
- (void) ::sysctl(mib,2,&numCPUs,&len,NULL,0);
- if (numCPUs < 1)
- numCPUs = 1;
- return (UInt32) numCPUs;
- #endif
- #if(__linux__ || __linuxppc__)
- char cpuBuffer[8192] = "";
- StrPtrLen cpuInfoBuf(cpuBuffer, sizeof(cpuBuffer));
- FILE *cpuFile = ::fopen( "/proc/cpuinfo", "r" );
- if (cpuFile)
- { cpuInfoBuf.Len = ::fread(cpuInfoBuf.Ptr, sizeof(char), cpuInfoBuf.Len, cpuFile);
- ::fclose(cpuFile);
- }
- StringParser cpuInfoFileParser(&cpuInfoBuf);
- StrPtrLen line;
- StrPtrLen word;
- UInt32 numCPUs = 0;
- while( cpuInfoFileParser.GetDataRemaining() != 0 )
- {
- cpuInfoFileParser.GetThruEOL(&line); // Read each line
- StringParser lineParser(&line);
- lineParser.ConsumeWhitespace(); //skip over leading whitespace
- if (lineParser.GetDataRemaining() == 0) // must be an empty line
- continue;
- lineParser.ConsumeUntilWhitespace(&word);
- if ( word.Equal("processor") ) // found a processor as first word in line
- { numCPUs ++;
- }
- }
- if (numCPUs == 0)
- numCPUs = 1;
- return numCPUs;
- #endif
- #if(__solaris__)
- {
- UInt32 numCPUs = 0;
- char linebuff[512] = "";
- StrPtrLen line(linebuff, sizeof(linebuff));
- StrPtrLen word;
- FILE *p = ::popen("uname -X","r");
- while((::fgets(linebuff, sizeof(linebuff -1), p)) > 0)
- {
- StringParser lineParser(&line);
- lineParser.ConsumeWhitespace(); //skip over leading whitespace
- if (lineParser.GetDataRemaining() == 0) // must be an empty line
- continue;
- lineParser.ConsumeUntilWhitespace(&word);
- if ( word.Equal("NumCPU")) // found a tag as first word in line
- {
- lineParser.GetThru(NULL,'=');
- lineParser.ConsumeWhitespace(); //skip over leading whitespace
- lineParser.ConsumeUntilWhitespace(&word); //read the number of cpus
- if (word.Len > 0)
- ::sscanf(word.Ptr, "%"_U32BITARG_"", &numCPUs);
- break;
- }
- }
- if (numCPUs == 0)
- numCPUs = 1;
- ::pclose(p);
- return numCPUs;
- }
- #endif
- #if(__sgi__)
- UInt32 numCPUs = 0;
- numCPUs = sysconf(_SC_NPROC_ONLN);
- return numCPUs;
- #endif
- return 1;
- }
PS: 函数摘自Darwin源码:\StreamServer\CommonUtilitiesLib\OS.cpp
【Darwin学习笔记】之获取系统处理器数量的方法的更多相关文章
- Jquery学习笔记:获取jquery对象的基本方法
jquery最大的好处是将js对html页面的操作(读写)进行了封装,隔离了浏览器的差异性,并简化了操作,和提供了强大的功能. 在web页面中,所有的js操作都是围绕操作dom对象来的.而jquery ...
- Linux学习笔记(七) 查询系统
1.查看命令 (1)man 可以使用 man 命令名称 命令查看某个命令的详细用法,其显示的内容如下: NAME:命令名称 SYNOPSIS:语法 DESCRIPTION:说明 OPTIONS:选项 ...
- openresty 学习笔记二:获取请求数据
openresty 学习笔记二:获取请求数据 openresty 获取POST或者GET的请求参数.这个是要用openresty 做接口必须要做的事情.这里分几种类型:GET,POST(urlenco ...
- C#获取CPU处理器核心数量的方法_C#教程
https://yq.aliyun.com/ziliao/89096 摘要: 本文讲的是C#获取CPU处理器核心数量的方法_C#教程, 有几条不同的处理器信息,您可以获得有关的信息:物理处理器数量.核 ...
- Android获取系统时间的多种方法
Android中获取系统时间有多种方法,可分为Java中Calendar类获取,java.util.date类实现,还有android中Time实现. 现总结如下: 方法一: ? 1 2 3 4 5 ...
- vue学习笔记之:为何data是一个方法
vue学习笔记之:为何data是一个方法 在vue开发中,我们可以发现,data中的属性值是在function中return出来的.可为何data必须是一个函数呢?我们先看官方的解释: 当一个组件被定 ...
- WPF 获取系统 DPI 的多种方法
原文:WPF 获取系统 DPI 的多种方法 WPF 获取系统 DPI 的多种方法 由于 WPF 的尺寸单位和系统的 DPI 相关,我们有时需要获取 DPI 值来进行一些界面布局的调整,本文汇总了一些 ...
- [学习笔记] Numpy基础 系统学习
[学习笔记] Numpy基础 上专业选修<数据分析程序设计>课程,老师串讲了Numpy基础,边听边用jupyter敲了下--理解+笔记. 老师讲的很全很系统,有些点没有记录,在PPT里就不 ...
- SAS学习笔记59 OPTIONS系统选项
带VALUE选项的OPTIONS过程将指定选项的值.范围及该值如何设置的信息打印到日志窗口 在日志窗口打印的输出如下图所示 将GETOPTION函数作为%SYSFUNC宏函数的参数,从而获取系统选项设 ...
随机推荐
- 阿里云ECS服务器购买流程 (自定义配置购买、按月、按量购买)教程
阿里ECS云服务器自定义购买流程 本文提供全图文流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- ...
- 多点搜的bfs
Problem L. 跑图Time limit: 1000msMemory limit: 65536KBDescription跑图是 RPG 游戏中很烦躁的事情.玩家需要跑到距离他最近的传送点的位置. ...
- xdoj-1279(有趣的线段树--吉司机?!)
题目链接 一 核心: f(x)=91 (x<=100) f(x)=x-10 (x>100) 那么同一区间就可能不同的操作,那么该怎么解决呢? 我门直到同一区间的数据属于同一类别的时候再进行 ...
- kmp--看毛片算法
string str; int next[N];// 核♥: next[k] 字符串前(k-1)个元素有next[k]个相等前后缀 // 初始化 next[0]=-1; next[1]=0; void ...
- Structural Features for Predicting the Linguistic Quality of Text: Applications to Machine Translation, Automatic Summarization and Human-Authored Text -paper
abstract句子结构是文本语言质量的关键,我们记录了以下实验结果:句法短语统计和其他结构特征对文本方面的预测能力.手工评估的句子fluency流利度用于机器翻译评估和文本摘要质量的评估是黄金准则. ...
- NYOJ 85:有趣的数(打表,规律)
85-有趣的数 内存限制:64MB 时间限制:3000ms 特判: No 通过数:8 提交数:12 难度:2 题目描述: 把分数按下面的办法排成一个数表. 1/1 1/2 1/3 1/4- 2/1 2 ...
- 嵌套for
- hdu 1280 堆排序
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s) ...
- odoo软件名称及授权协议的变化
先看一张表格 起步时叫TinyERP,微小的ERP:发展中期叫做OpenERP,开放的ERP:历经10年积累的软件,客户群,开发支持用户群,开始构筑自己的商业模式.到8版本,改名为Odoo.同时,软件 ...
- Cassandra如何保证数据最终一致性
Cassandra如何保证数据最终一致性:1.逆熵机制(Anti-Entropy)使用默克尔树(Merkle Tree)来确认多个副本数据一致,对于不一致数据,根据时间戳来获取最新数据. 2.读修复机 ...