我的编程空间,编程开发者的网络收藏夹
学习永远不晚

OPENMP SECTIONS CONSTRUCT原理是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

OPENMP SECTIONS CONSTRUCT原理是什么

今天小编给大家分享一下OPENMP SECTIONS CONSTRUCT原理是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

编译器角度分析

在这一小节当中我们将从编译器角度去分析编译器会怎么处理 sections construct ,我们以下面的 sections construct 为例子,看看编译器是如何处理 sections construct 的。

#pragma omp sections{  #pragma omp section  stmt1;  #pragma omp section  stmt2;  #pragma omp section  stmt3;}

上面的代码会被编译器转换成下面的形式,其中 GOMP_sections_start 和 GOMP_sections_next 是并发安全的,他们都会返回一个数据表示第几个 omp section 代码块,其中 GOMP_sections_start 的参数是表示有几个 omp section 代码块,并且返回给线程一个整数表示线程需要执行第几个 section 代码块,这两个函数的意义不同的是在 GOMP_sections_start 当中会进行一些数据的初始化操作。当两个函数返回 0 的时候表示所有的 section 都被执行完了,从而退出 for 循环。

for (i = GOMP_sections_start (3); i != 0; i = GOMP_sections_next ())  switch (i)    {    case 1:      stmt1;      break;    case 2:      stmt2;      break;    case 3:      stmt3;      break;    }GOMP_barrier ();

动态库函数分析

事实上在函数 GOMP_sections_start 和函数 GOMP_sections_next 当中调用的都是我们之前分析过的函数 gomp_iter_dynamic_next ,这个函数实际上就是让线程始终原子指令去竞争数据块(chunk),这个特点和 sections 需要完成的语意是相同的,只不过 sections 的块大小(chunk size)都是等于 1 的,因为一个线程一次只能够执行一个 section 代码块。

unsignedGOMP_sections_start (unsigned count){  // 参数 count 的含义就是表示一共有多少个 section 代码块  // 得到当线程的相关数据  struct gomp_thread *thr = gomp_thread ();  long s, e, ret;  // 进行数据的初始化操作  // 将数据的 chunk size 设置等于 1  // 分割 chunk size 的起始位置设置成 1 因为根据上面的代码分析 0 表示退出循环 因此不能够使用 0 作为分割的起始位置  if (gomp_work_share_start (false))    {    // 这里传入 count 作为参数的原因是需要设置 chunk 分配的最终位置 具体的源代码在下方      gomp_sections_init (thr->ts.work_share, count);      gomp_work_share_init_done ();    }  // 如果获取到一个 section 的执行权 gomp_iter_dynamic_next 返回 true 否则返回 false   // s 和 e 分别表示 chunk 的起始位置和终止位置 但是在 sections 当中需要注意的是所有的 chunk size 都等于 1  // 这也很容易理解一次执行一个 section 代码块  if (gomp_iter_dynamic_next (&s, &e))    ret = s;  else    ret = 0;  return ret;}// 下面是部分 gomp_sections_init 的代码static inline voidgomp_sections_init (struct gomp_work_share *ws, unsigned count){  ws->sched = GFS_DYNAMIC;  ws->chunk_size = 1; // 设置 chunk size 等于 1  ws->end = count + 1L; // 因为一共有 count 个 section 块  ws->incr = 1; // 每次增长一个  ws->next = 1; // 从 1 开始进行 chunk size 的分配 因为 0 表示退出循环(编译器角度分析)}unsignedGOMP_sections_next (void){  // 这个函数就比较容易理解了 就是获取一个 chunk 拿到对应的 section 的执行权  long s, e, ret;  if (gomp_iter_dynamic_next (&s, &e))    ret = s;  else    ret = 0;  return ret;}// 下面的函数在之前的很多文章当中都分析过了 这里不再进行分析// 下面的函数的主要过程就是使用 CAS 指令不断的进行尝试,直到获取成功或者全部获取完成 没有 chunk 需要分配boolgomp_iter_dynamic_next (long *pstart, long *pend){  struct gomp_thread *thr = gomp_thread ();  struct gomp_work_share *ws = thr->ts.work_share;  long start, end, nend, chunk, incr;  end = ws->end;  incr = ws->incr;  chunk = ws->chunk_size;  if (__builtin_expect (ws->mode, 1))    {      long tmp = __sync_fetch_and_add (&ws->next, chunk);      if (incr > 0)  {    if (tmp >= end)      return false;    nend = tmp + chunk;    if (nend > end)      nend = end;    *pstart = tmp;    *pend = nend;    return true;  }      else  {    if (tmp <= end)      return false;    nend = tmp + chunk;    if (nend < end)      nend = end;    *pstart = tmp;    *pend = nend;    return true;  }    }  start = ws->next;  while (1)    {      long left = end - start;      long tmp;      if (start == end)  return false;      if (incr < 0)  {    if (chunk < left)      chunk = left;  }      else  {    if (chunk > left)      chunk = left;  }      nend = start + chunk;      tmp = __sync_val_compare_and_swap (&ws->next, start, nend);      if (__builtin_expect (tmp == start, 1))  break;      start = tmp;    }  *pstart = start;  *pend = nend;  return true;}

以上就是“OPENMP SECTIONS CONSTRUCT原理是什么”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

OPENMP SECTIONS CONSTRUCT原理是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

OPENMP SECTIONS CONSTRUCT原理是什么

今天小编给大家分享一下OPENMP SECTIONS CONSTRUCT原理是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下
2023-07-05

OPENMP SECTIONS CONSTRUCT原理示例解析

这篇文章主要为大家介绍了OPENMP SECTIONS CONSTRUCT原理示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-03-06

OpenMP Parallel Construct的实现原理详解

在本篇文章当中我们将主要分析 OpenMP 当中的 parallel construct 具体时如何实现的,以及这个 construct 调用了哪些运行时库函数,并且详细分析这期间的参数传递,需要的可以参考一下
2023-01-28

OpenMP task construct实现原理源码分析

本篇内容主要讲解“OpenMP task construct实现原理源码分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“OpenMP task construct实现原理源码分析”吧!从编译器
2023-07-05

OpenMP中For Construct对dynamic的调度方式是什么

这篇文章主要介绍“OpenMP中For Construct对dynamic的调度方式是什么”,在日常操作中,相信很多人在OpenMP中For Construct对dynamic的调度方式是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好
2023-07-05

PHP中construct是什么意思

PHP中construct是指__construct()函数,该函数用于创建一个新的SimpleXMLElement对象,其语法是“__construct(data,options,is_url,ns,is_prefix)”。
2015-09-07

PHP中construct指的是什么意思

这篇文章主要介绍PHP中construct指的是什么意思,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!PHP中construct是指__construct()函数,该函数用于创建一个新的SimpleXMLElemen
2023-06-22

immer.js原理是什么

这篇文章主要介绍了immer.js原理是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇immer.js原理是什么文章都会有所收获,下面我们一起来看看吧。但如果拷贝的是一个树形结构,层次比较深,看是一个对象,
2023-07-05

DHCP是什么?工作原理是什么?

  在设置无线AP或无线路由器过程中,用户会遇到很多参数,如果只是完成一般的设置,满足一般的上网需求的话,有以一些参数是不需要深入了解的。但是在一些比较复杂的网络环境就需要我们对一些参数作相应的配置,今天我们来看一下无线路由器的参数之一DHCP。  1、DHCP的作用  DHCP(Dynamic Host Confif
DHCP是什么?工作原理是什么?
2024-04-18

JUC CountDownLach原理是什么

本篇内容主要讲解“JUC CountDownLach原理是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JUC CountDownLach原理是什么”吧! CountDownLach闭锁背景
2023-06-16

Spring MVC原理是什么

这篇文章将为大家详细讲解有关Spring MVC原理是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。springMVC,是spring的一个子框架,当然拥有spring的特性,如依赖注入。在web模型
2023-06-27

webservice的原理是什么

Web服务的原理是通过使用HTTP协议进行通信,提供一组标准化的接口和方法,使不同的应用程序能够相互交互和通信。以下是Web服务的基本原理:服务描述:Web服务通过WSDL(Web Services Description Language
webservice的原理是什么
2024-02-29

CAS的原理是什么

本篇内容介绍了“CAS的原理是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在并发编程中我们都知道i++操作是非线程安全的,这是因为 i
2023-06-15

AOP的原理是什么

这篇文章主要讲解了“AOP的原理是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“AOP的原理是什么”吧!AOP的原理对哪些对象在什么位置拦截做什么 <=>
2023-06-03

redis的原理是什么

redis 是一款内存数据库,使用单线程架构和复杂的数据结构,实现了高性能和可扩展性。它支持数据持久化和复制,以确保数据安全性和可用性。Redis 的原理Redis 是一款开源的高性能键值对数据库,它以其快速、可靠和可扩展性而闻名。它的工
redis的原理是什么
2024-04-20

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录