需求
我们在编程时,尤其是在涉及到系统环境的程序开发中,可能会需要动态的获得当前机器中可用的CPU核数。例如,当我们需要做并行计算时,我们可能会根据CPU核数来决定并行度,因此我们需要在C程序中获得当前机器中可用的CPU核数。
方法
GetSystemInfo(&info);
return info.dwNumberOfProcessors;
而在Linux平台下,我们可以使用sysconf()或者get_nprocs()来获取处理器核数。下面分别介绍:
sysconf( )有unistd.h提供,要使用该函数需要#include<unistd.h>,其参数可以是_SC_NPROCESSORS_CONF,也可以是_SC_NPROCESSORS_ONLN。sysconf(_SC_NPROCESSORS_CONF)返回系统可以使用的核数,但是其值会包括系统中禁用的核的数目,因此该值并不代表当前系统中可用的核数。而sysconf(_SC_NPROCESSORS_ONLN)的返回值真正的代表了系统当前可用的核数。
GNU C库提供了另外一种获取机器可用核数的方法。函数intget_nprocs_conf (void),int get_nprocs (void)在 sys/sysinfo.h中定义,这两个函数可用获取机器的核数。其中get_nprocs_conf (void)的返回值与sysconf(_SC_NPROCESSORS_CONF)类似,并不真正表名当前可用核数;而get_nprocs (void)的返回值与sysconf(_SC_NPROCESSORS_ONLN)类似,真正的反映了当前可用核数。
跨平台函数
跨平台的获取系统当前可用核数的函数如下所示:
Int_t get_CPU_core_num( )
{
#if defined(WIN32)
SYSTEM_INFO info;
GetSystemInfo(&info);
return info.dwNumberOfProcessors;
#elif defined(LINUX) || defined(SOLARIS) || defined(AIX)
return get_nprocs(); //GNU fuction
#else
#error 不支持的操作系统
#endif
}小结
获取系统当前可用核数,是并行计算中确定并行度的一种常用方法,通过本文的小函数,可用学到如何获取当前可用核数。

本文介绍了如何在C程序中跨平台地获取当前机器的可用CPU核数,这对于确定并行计算的并行度非常重要。文章详细展示了在Windows平台下使用GetSystemInfo()函数,在Linux平台下使用sysconf()或get_nprocs()函数的具体实现。
核数&spm=1001.2101.3001.5002&articleId=8123864&d=1&t=3&u=96442cdd82c147be8445859822f62953)
8502

被折叠的 条评论
为什么被折叠?



