C语言并行程序编程(一)

这里先简单书写一个并行版的hello world 作为入门,后续的文章再更新相关的概念。

#include 
#include 
#include 

void Hello(void);

int main(int argc,char* argv[])
{
    int thread_count = strtol(argv[1],NULL,10);
    //获取线程数
#   pragma omp parallel num_threads(thread_count)
    Hello();
    return 0;
}

void Hello(void)
{
    int my_rank = omp_get_thread_num();
    //获取线程编号
    int thread_count = omp_get_num_threads();
    //获取线程数

    printf("Hello World from thread %d of %d\n",my_rank,thread_count);
}

接着运行一下,先看一下结果

在源文件的文件夹下打开终端输入: gcc -g -Wall -fopenmp -o test test.c

C语言并行程序编程(一)_第1张图片

得到一个文件名为test的文件,接着输入:./test 4,得到运行结果

C语言并行程序编程(一)_第2张图片

下面我先来解释一下编译命令的作用:

-g:允许使用调试器 ; -Wall:显示警告;-fopenmp:防止老版本的gcc不包含OpenMP的支持;

-o 便以后的可执行文件的文件名为outfile;./:用来给出可执行文件的路径;4代表开启的线程数。

接着我来解释一下源代码,可能会牵扯到一些术语,我会在后面的文章中作更详细的解释,在这里就不作过多的赘述了。

strtol函数:获取线程数,包含在中。其原型为:

long strtol(const char* number p  /* in */,
            char** end p         /* out */,
            int   base           /* in */
);

参数一是一个字符串,在这个例子中为命令行参数;参数二因为没有用到,所以传递了一个空指针;参数三是字符串所代表的数的基数,代码中的10代表十进制

在C/C++中,预处理指令以#pragma,在OpenMP中,常常以#pragma omp开始

parallel指令用来表明之后的结构化代码块(基本块)应该被多个线程并行执行。

将num_threads子句加入到parallel指令中,就允许程序员指定执行后代码块的线程数。

在Hello函数中,我们分别获取了线程的编号和线程数,它们的原型如下:

int my_rank = omp_get_thread_num(void);         //获取线程编号
int thread_count = omp_get_num_threads(void);   //获取线程数

相关概念我会在后面的文章中一一解释,欢迎大家一起来学习,QQ交流群:892747839

你可能感兴趣的:(C)