OpenMP简介

7 篇文章 0 订阅

介绍

OpenMP 是一个应用程序接口 (API),由一组主要的计算机硬件和软件供应商共同定义。OpenMP 为共享内存并行应用程序的开发人员提供了一个可移植、可扩展的模型。该 API 支持各种架构上的 C/C++ 和 Fortran。

OpenMP是:

  • 一个可用于显式指导多线程、共享内存并行计算的应用程序接口(API)
  • 由三个主要的API组件组成:
    • 编译器指令
    • 运行时库例程
    • 环境变量
  • 其缩写为:
    • 简称:Open Multi-Processing
    • 长版本:通过硬件和软件行业、政府和学术界感兴趣的各方之间的合作工作开放的多处理规范

OpenMP不是:

  • 所有供应商都必须以相同方式实现的
  • 保证对共享内存的最有效利用
  • 必须检查数据依赖性、数据冲突、竞争条件或死锁
  • 必须检查导致程序被归类为不符合规范的代码序列
  • 旨在保证在并行执行时对同一文件的输入或输出是同步的。程序员负责同步输入和输出。

OpenMP的目标:

  • 标准化
    • 为各种共享内存架构/平台提供标准
    • 由一组主要计算机硬件和软件供应商共同定义和支持
  • 精简高效
    • 建立一套简单且有限的指令集,用于编程共享内存机器。
    • 只需使用3或4个指令,即可实现显著的并行性。
    • 这一目标似乎在每个新版本中变得不那么有意义。
  • 易用性
    • 提供逐步并行化串行程序的能力,与通常需要一揽子方法的消息传递库不同
    • 提供实现粗粒度和细粒度并行性的能力
  • 可移植性
    • API已为C/C++和Fortran指定
    • API和会员的公共论坛
    • 大多数主要平台都已实现,包括Unix/Linux平台和Windows
  • 14
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值