Linux CPU数量判断

本文详细解析如何通过Linux命令`cat/proc/cpuinfo`获取CPU的逻辑和物理数量,以及判断CPU是否支持超线程技术,并提供实例进行验证。同时,指导如何从输出信息中获取更多关于处理器的详细特征。

其实只要


#include<unistd.h>
long num = sysconf(_SC_NPROCESSORS_ONLN);


便可以获得当前CPU的数量。。。


判断依据:
1.具有相同core id的cpu是同一个core的超线程。
2.具有相同physical id的cpu是同一颗cpu封装的线程或者cores。


英文版:
1.Physical id and core id are not necessarily consecutive but theyare unique. Any cpu with the same core id are hyperthreads in thesame core.
2.Any cpu with the same physical id are threads or cores in thesame physical socket.


实例:


LunarPages的CPU信息:


processor : 0
vendor_id : GenuineIntel
cpu family : 15
model : 4
model name : Intel(R) Xeon(TM) CPU 3.00GHz
stepping : 3
cpu MHz : 3000.881
cache size : 2048 KB
physical id : 0
siblings : 2
core id : 0
cpu cores : 1
fdiv_bug : no
hlt_bug : no
f00f_bug : no
coma_bug : no
fpu : yes
fpu_exception : yes
cpuid level : 5
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic mtrr pge mca cmovpat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe lmconstant_tsc pni monitor ds_cpl cid xtpr
bogomips : 6006.73


 


processor : 1
vendor_id : GenuineIntel
cpu family : 15
model : 4
model name : Intel(R) Xeon(TM) CPU 3.00GHz
stepping : 3
cpu MHz : 3000.881
cache size : 2048 KB
physical id : 0
siblings : 2
core id : 0
cpu cores : 1
fdiv_bug : no
hlt_bug : no
f00f_bug : no
coma_bug : no
fpu : yes
fpu_exception : yes
cpuid level : 5
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic mtrr pge mca cmovpat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe lmconstant_tsc pni monitor ds_cpl cid xtpr
bogomips : 5999.40


 


processor : 2
vendor_id : GenuineIntel
cpu family : 15
model : 4
model name : Intel(R) Xeon(TM) CPU 3.00GHz
stepping : 3
cpu MHz : 3000.881
cache size : 2048 KB
physical id : 3
siblings : 2
core id : 3
cpu cores : 1
fdiv_bug : no
hlt_bug : no
f00f_bug : no
coma_bug : no
fpu : yes
fpu_exception : yes
cpuid level : 5
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic mtrr pge mca cmovpat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe lmconstant_tsc pni monitor ds_cpl cid xtpr
bogomips : 5999.08


 


processor : 3
vendor_id : GenuineIntel
cpu family : 15
model : 4
model name : Intel(R) Xeon(TM) CPU 3.00GHz
stepping : 3
cpu MHz : 3000.881
cache size : 2048 KB
physical id : 3
siblings : 2
core id : 3
cpu cores : 1
fdiv_bug : no
hlt_bug : no
f00f_bug : no
coma_bug : no
fpu : yes
fpu_exception : yes
cpuid level : 5
wp : yes
flags : fpu vme de pse tsc msr pae mce cx8 apic mtrr pge mca cmovpat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe lmconstant_tsc pni monitor ds_cpl cid xtpr
bogomips : 5999.55


显示4个逻辑CPU,通过physical id,前面两个逻辑cpu的相同,后面两个的相同,所以有两个物理CPU。前面两个的core id相同,后面的两个core ID相同,说明这两个CPU都是单核。也就是说两个单核cpu,启用了超线程技术。
通过intel的cpu的参数可以初步判断 使用的是两个 Xeon奔腾4CPU ,有点差。。。。
如何获得CPU的详细信息:


linux命令:cat /proc/cpuinfo


用命令判断几个物理CPU,几个核等:


逻辑CPU个数:
# cat /proc/cpuinfo | grep 'processor' | wc -l


物理CPU个数:
# cat /proc/cpuinfo | grep 'physical id' | sort | uniq | wc -l


每个物理CPU中Core的个数:
# cat /proc/cpuinfo | grep 'cpu cores' | wc -l


是否为超线程?
如果有两个逻辑CPU具有相同的”core id”,那么超线程是打开的。


每个物理CPU中逻辑CPU(可能是core, threads或both)的个数:
# cat /proc/cpuinfo | grep 'siblings'
其他特征:


目前intel新的多核心cpu都会在后面显示具体的型号数字,例如:


model name : Intel(R) Xeon(R)CPU          X3230   @ 2.66GHz


说明是 Xeon 3230的cpu,而不显示型号的具体数字的,大部分都是奔腾的CPU


很多主机商都骗人,用奔腾的cpu,却说是多核心的CPU。


探针看到的数据:


类型:Intel(R) Xeon(TM) CPU 2.80GHz 缓存:1024 KB
类型:Intel(R) Xeon(TM) CPU 2.80GHz 缓存:1024 KB
类型:Intel(R) Xeon(TM) CPU 2.80GHz 缓存:1024 KB
类型:Intel(R) Xeon(TM) CPU 2.80GHz 缓存:1024 KB


没有具体的型号,缓存1M,一般都是奔腾系列的cpu,或者是intel假双核的cpu,具体要根据上面说的去判断。新的多核心cpu都能看到具体的型号。
另外多核心的xeon的CPU,一般主频都不高,达到2.8和3.0的只有很少的几个高端CPU型号,一般主机商不会用这么好的。



一些操作系统的最新版本已经更新了 /proc/cpuinfo 文件,以支持多路平台。如果您的系统中的 /proc/cpuinfo文件能够正确地反映出处理器信息,那么就不需要执行上述步骤。反之,可采用本文中的信息进行解释。


/proc/cpuinfo 文件包含系统上每个处理器的数据段落。/proc/cpuinfo 描述中有 6个条目适用于多内核和超线程(HT)技术检查:processor, vendor id, physical id, siblings,core id 和 cpu cores。


processor 条目包括这一逻辑处理器的唯一标识符。
physical id 条目包括每个物理封装的唯一标识符。
core id 条目保存每个内核的唯一标识符。
siblings 条目列出了位于相同物理封装中的逻辑处理器的数量。
cpu cores 条目包含位于相同物理封装中的内核数量。


如果处理器为英特尔处理器,则 vendor id 条目中的字符串是 GenuineIntel。


1.拥有相同 physical id 的所有逻辑处理器共享同一个物理插座。每个 physical id代表一个唯一的物理封装。


2.Siblings 表示位于这一物理封装上的逻辑处理器的数量。它们可能支持也可能不支持超线程(HT)技术。


3.每个 core id 均代表一个唯一的处理器内核。所有带有相同 core id的逻辑处理器均位于同一个处理器内核上。


4.如果有一个以上逻辑处理器拥有相同的 core id 和 physical id,则说明系统支持超线程(HT)技术。


5.如果有两个或两个以上的逻辑处理器拥有相同的 physical id,但是 core id不同,则说明这是一个多内核处理器。cpu cores 条目也可以表示是否支持多内核。


例如,如果系统包含两个物理封装,每个封装中又包含两个支持超线程(HT)技术的处理器内核,则 /proc/cpuinfo文件将包含此数据。(注:数据并不在表格中。)

源码链接: https://pan.quark.cn/s/a4b39357ea24 Modbus协议是一种普遍应用的通信协议,在工业自动化领域具有显著地位,它为不同设备间的客户机/服务器通信确立了标准。该协议立足于OSI模型的第7层,即应用层,旨在实现通过多种总线或网络连接的设备之间的数据交换。Modbus协议主要由三个核心部分构成: 1. **Modbus协议规范**:这部分详细阐述了MODBUS事务处理机制,包括如何组织和发送请求/响应报文。它定义了一组功能码,这些功能码是MODBUS协议的数据包(PDU)的组成部分,用于表明不同的服务操作。 2. **MODBUS报文传输在TCP/IP上的实现指南**:这一部分为开发者提供了在TCP/IP上实现MODBUS应用层的指导,参考了IETF的标准RFC793(TCP)和RFC791(IP),以确保MODBUS报文能在网络上正确传输。 3. **MODBUS报文传输在串行链路上的实现指南**:针对使用如EIA-232和EIA-485等串行通信标准的设备,提供了实现MODBUS应用层的指导,确保在串行链路上的数据完整性。 MODBUS协议支持两种通信模式: - **Modbus RTU (Remote Terminal Unit)**:适用于异步串行通信,通常用于低速、短距离通信,如EIA/TIA-232、EIA-422和EIA/TIA-485。 - **Modbus TCP/IP**:基于互联网协议,使用以太网II/802.3标准,适合高速、远程通信。 在MODBUS通信栈中,MODBUS应用层位于TCP/IP之上,借助TCP的可靠连接特性,确保数据包按顺序到达。而在串行链路上,MODBUS协议则直接与物理层交...
源码直接下载地址: https://pan.quark.cn/s/31ad939aed54 "关于 SR 锁存器的解析及其应用" SR 锁存器被视为一种核心的数字电子技术部件,它在数字电路构建和计算机系统的开发中占据着举足轻重的地位。SR 锁存器的构造基础是两个与非门,具体标识为 G1 和 G2。该锁存器的工作机制主要依托于 S 和 R 两个输入端信号的逻辑关联,以此来调控输出端 Q 的状态。 SR 锁存器的工作机制可以依据输入信号的不同组合分为四种情形: 1. 在 R=0、S=0 的条件下,状态将保持恒定,即 Qn+1 等同于 Qn。 2. 当 R=0、S=1 时,执行置位操作,使得 Qn+1=1。 3. 若 R=1、S=0,则执行复位操作,导致 Qn+1=0。 4. 当 R=1、S=1 时,状态呈现不确定特性,输出端 Q 的具体状态无法预测。 SR 锁存器的实践应用极为普遍,譬如在数字电路的规划中,它能够充当 Flip-Flop 功能的载体,常见于计数器、寄存器以及计算机系统之中。此外,SR 锁存器也被广泛用于消弭由机械开关触点颤动所引发的脉冲信号输出问题。 逻辑门控 SR 锁存器可视为 SR 锁存器的一种演进形态,它通过增设使能信号 E,对 SR 锁存器的输出进行调控。逻辑门控 SR 锁存器的运作机制基于 E、S 以及 R 三个输入端信号的逻辑联系,用以控制输出端 Q 的状态。 逻辑门控 SR 锁存器的应用场景同样十分多样,例如在数字电路的设计过程中,它能够协助实现更为复杂的逻辑操作。 D 锁存器亦是一种基础性的数字电子技术器件,其运作原理与 SR 锁存器相近,但 D 锁存器的输出端 Q 仅受输入信号 D 的影响。D 锁存器的实践用途同样广泛,例如在数字电路的...
源码直接下载地址: https://pan.quark.cn/s/96ee77ac4da8 根据题目指示,我们将从标题“C 语言 打印沙漏”、描述“PAT 测试题 打印沙漏 但是不知道为什么我的提交就是无效”以及部分提供的代码片段入手,对与“打印沙漏”相关的基础知识进行深入剖析。 ### 一、问题背景 题目要求在 C 语言环境下开发程序,用以生成一个沙漏形态。该任务属于 PAT(Programming Ability Test)考试中的一个环节,主要评估考生对循环结构的掌握和应用水平。从描述信息来看,尽管提交者已经完成了代码的编写工作,但在 PAT 平台上却显示提交无效。这或许是因为程序在逻辑上存在偏差或未能满足题目的具体规范所致。 ### 二、打印沙漏的原理 #### 1. 沙漏的基本构造 沙漏由上下两个对称部分构成。每一行均由一定数量的星号和空格组成。随着行数的改变,星号的数量也会发生相应的增减变化。 #### 2. 实现过程 - **确定沙漏的规模**:首先需要明确沙漏的总行数(n),这将直接影响沙漏的最大宽度。 - **计算每一行的星号数目**:对于第 i 行(i 从 1 开始计算),其星号数目遵循公式 `2 * (n - abs(i - n)) - 1` 进行确定。 - **确定每行的空格数目**:对于第 i 行,空格数目为 `abs(n - i) - 1`。 - **输出星号和空格**:依据计算出的数量,依次输出星号和空格即可完成一行的打印。 #### 3. 代码范例 下面给出一个基础的 C 语言代码范例,用于生成沙漏: ```c #include <stdio.h> int main() { int n; printf("请输入沙漏的行数:"); sc...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值