rdware_concurrency() 经常返回0,因为其实现可能无法探测系统信息,如旧版libstdc++、嵌入式环境或/proc不可用时会返回0,表示“无法确定”而非“无CPU”。
std::thread::hardware_concurrency() 是 C++11 起提供的标准接口,用于获取系统建议的并发线程数。但它不保证返回有效值——很多实现(尤其是旧版 libstdc++、某些嵌入式或容器环境)在无法探测时直接返回 0。
0 并不表示“无 CPU”,而是“实现无法确定”,比如未启用 _GLIBCXX_PARALLEL、/proc 不可用、或 Windows 上 GetSystemInfo 失败比 std::thread::hardware_concurrency() 更稳定,且 POSIX 标准,glibc 和 musl 都支持。它读取当前在线(online)的逻辑处理器数量,等价于 getconf _NPROCESSORS_ONLN 命令结果。
int n = sysconf(_SC_NPROCESSORS_ONLN);
if (n < 1) {
n = 1; // fallback
}
_SC_NPROCESSORS_ONLN:只统计当前启用的逻辑核(/sys/devices/system/cpu/online),热插拔后会变化/sys/devices/system/cpu/cpu*/topology/core_id 去重,或调用 lscpu 解析输出(非标准,不推荐嵌入)Windows 没有 POSIX sysconf,但 GetSystemInfo() 简单可靠,返回的是逻辑处理器数量(含超线程)。
#ifdef _WIN32 #includeSYSTEM_INFO si; GetSystemInfo(&si); int n = static_cast (si.dwNumberOfProcessors); #endif
dwNumberOfProcessors 是逻辑核数,和 Linux 的 _SC_NPROCESSORS_ONLN 行为一致GetLogicalProcessorInformation() + 解析 RELATIONSHIP,代码量大且易出错,多数场景不需要GetSystemInfo,无需额外链接别写 “if Linux / else if Windows” 运行时分支。优先用编译宏选路径,再 fallback 到 std::thread::hardware_concurrency(),最后兜底为 1 或 2。
sysconf)sysctlbyname("hw.logicalcpu", ...),而非 sysconf
sysctlbyname 和 sysconf 可能设 errno
cpus)下,sysconf(_SC_NPROCESSORS_ONLN) 仍返回宿主机总核数,而非 cgroup 允许的核数。真要适配容器,得读 /sys/fs/cgroup/cpu.max(cgroup v2)或 /sys/fs/cgroup/cpu/cpu.cfs_quota_us(v1),那已是另一个层级的问题了。