《并行计算的编程模型》一2.5.1 GASNet工具

本文介绍了GASNet工具接口,该接口独立于GASNet规范,旨在减少代码重复并提供统一的支持抽象。这些工具包括内存屏障、原子性操作、编译器注释等功能,适用于高性能计算环境。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

2.5.1 GASNet工具

在各种系统实现GASNet过程中,开发团队发现需要统一支持的各种抽象。因为同一个团队同时负责了HPC和Titanium语言运行时,相同抽象需要复制三次(包括复杂的autoconf逻辑和C预处理器宏)的特性逐渐凸显出来,除非GASNet为客户端提供了公共实现。因此独立于GASNet规范的“GASNet工具”接口应运而生。当其包含在GASNet中时,可以获得单独的GASNet发布版本而无需GASNet的其他部分(即没有核心或扩展API)。当然,无论是作为GASNet中的一部分还是从独立发布版本中获取的工具,接口都全部记录在文件README-tools中。工具API中的一些功能简单介绍如下所示:

  • 内存屏障:例如,用于编写自旋锁构造,特别是对于比x86更弱的内存模型体系架构。
  • 原子性:例如用于编写无锁的数据结构。
  • 编译器注释:允许便捷地使用GNU C_?_attribute_?_和与其等效的其他编译器操作。
  • 分支预测:便捷地应用分支预测提示。
  • 回滚:从各种C库实现和外部调试器中获取堆栈跟踪信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值