std::thread::hardware_concurrency() 返回 0 时应启用多层 fallback:优先读取 Linux 的 /sys/devices/system/cpu/online、Windows 的 GetSystemInfo() 或 macOS 的 sysctlbyname("hw.logicalcpu"),再退至保守值。
这个函数不保证返回有效值,标准只要求“尽力而为”,某些环境下(比如容器、Wine、旧内核或编译器未正确识别硬件)会直接返回 0。不能把它当作绝对可靠的 CPU 核心数来源。
docker run --cpus=2 时,hardware_concurrency() 仍可能返回宿主机总数或 0)0,应有 fallback 逻辑,不要直接除零或 crash这是内核暴露的真实在线逻辑 CPU 列表(考虑热插拔和 cpuset 限制),比 sysconf(_SC_NPROCESSORS_ONLN) 更贴近运行时实际可用数。
/sys/devi
ces/system/cpu/online 内容形如 0-3,6,8-9,需解析范围并计数get_nprocs_conf() 更准——后者返回配置最大值,可能包含被禁用的 corestd::ifstream f("/sys/devices/system/cpu/online");
std::string range; getline(f, range);
int count = parse_cpu_range(range); // 需自行实现逗号+短横解析GetSystemInfo() 是 Win32 API 中最轻量、最广泛支持的方式,返回的是当前会话可见的逻辑处理器数量(受进程 affinity mask 和组策略限制)。
SYSTEM_INFO.dwNumberOfProcessors,类型为 DWORD
GetLogicalProcessorInformation() 简单,且不涉及内存分配或结构体枚举SetProcessAffinityMask()),该值仍是全局总数;要获取当前进程实际可用数,得调用 GetProcessAffinityMask() 并统计 bit 数真正健壮的代码需要分层 fallback:先试标准函数,失败则走系统 API,再不行才退到保守估计(如返回 1 或 2)。
std::thread::hardware_concurrency() —— 它在 MinGW、某些嵌入式 libc++ 或静态链接场景下极易失效sysctlbyname("hw.logicalcpu", ...),比 sysconf(_SC_NPROC_ONLN) 更准(后者在 Rosetta 2 下可能返回 x86_64 逻辑核数而非 Apple Silicon 实际值)/proc/cpuinfo 的 processor 行数、Windows 的 GetActiveProcessorCount()(Win10 1607+)、macOS 的 host_processor_info() 都有各自适用边界,但多数服务端应用只需前三个 fallback 就已足够。别忘了加日志输出真实探测结果,方便排查调度异常。