2> OpenMP中的for调度

本文探讨了OpenMP中的循环调度方式,包括静态、动态、引导和运行时调度。静态调度将任务均匀分配给线程,动态调度则根据线程完成情况动态分配。文章通过示例代码展示了不同调度策略在for循环中的应用,并讨论了参数如何影响任务分配。
摘要由CSDN通过智能技术生成

1、在for的任务分担中有几种不同的调度方式:静态调度和动态调度,非正式的解释静态调度就是每个线程分固定的任务,而动态调度可以理解为通过CPU进行调度,那个线程做完了,那个线程可能就会有新的任务,是动态分配任务的。


2、静态调度:

#pragma omp parallel for schedule(static) num_threads(2)

for(int i = 0; i < 4; i++ )

{

printf("i = %d, thread_num = %d\n", i, omp_get_thread_num());

}

以上代码的运行结果是什么呢………………结果是0号线程输出的i = 0和1,而1号线程输出的i = 2和3,这也就意味着每个线程是静态的划分了n/t次连续的任务(我们这里每个任务就是指一次循环输出,n代表循环的总次数,t并行域中总共的线程数)


3、静态调度:

#pragma omp parallel for schedule(static, 1) num_threads(2)

for(int i = 0; i < 4; i++ )

{

printf("i = %d, thread_num = %d\n", i, omp_get_thread_num());

}

后面加上参数2,表示每个线程分配2个连续的任务。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值