并行程序设计基础——并行I/O(2)

目录

一、显式偏移的并行文件读写

1、阻塞方式

1.1 MPI_FILE_READ_AT

1.2 MPI_FILE_WRITE_AT

1.3 MPI_FILE_READ_AT_ALL

1.4 MPI_FILE_WRITE_AT_ALL

2、非阻塞方式

2.1 MPI_FILE_IREAD_AT

2.2 MPI_FILE_IWRITE_AT

3、两步非阻塞组调用

3.1 MPI_FILE_READ_AT_ALL_BEGIN

3.2 MPI_FILE_READ_AT_ALL_END

3.3 MPI_FILE_WRITE_AT_ALL_BEGIN

3.4 MPI_FILE_WRITE_AT_ALL_END


        上一节我们介绍了MPI-2中新增加的特性“并行I/O”中的并行文件管理基本操作,本节我们继续对其余内容进行学习。

一、显式偏移的并行文件读写

        一种并行文件读写的方法是每一个进程都清楚地知道它将要处理的数据在文件中的准确位置,从而所有的进程可以同时对文件的不同部分进行读写,实现文件的并行操作。在显式偏移方式下,读取位置是作为一个参数传递给读写调用的,不需要文件指针,当然也不需要文件指针的更新。在这种方式下,是没有文件指针的概念的,当然也不需要文件指针的移动操作SEEK,它可以直接从任意指定的位置开始读写。

1、阻塞方式

1.1 MPI_FILE_READ_AT

        MPI_FILE_READ_AT从文件fh中的指定偏移位置offset开始,读取count个数据类型为datatype的数据,存放到数据缓冲区buf之中,status是该读写操作完成后返回的状态参数。

MPI_FILE_READ_AT(fh, offset, buf, count, datatype, status)
IN    fh            文件句柄
IN    offset        读取位置相对于文件头的偏移
OUT   buf           读取数据存放的缓冲区
IN    count         读取数据个数
IN    datatype      读取数据的数据类型
OUT   status        返回的状态参数

//c语言的说明
int MPI_File_read_at(MPI_File fh, MPI_Offset offset, void *buf, int count, MPI_Datatype datatype, MPI_Status *status)
//Fortran语言的说明
MPI_FILE_READ_AT(FH, OFFSET, BUF, COUNT, DATATYPE, STATUS, IERROR)
<type>  BUF(*)
INTEGER  FH, COUNT, DATATYPE, STATUS(MPI_STATUS_SIZE), IERROR
INTEGER(KIND=MPI_OFFSET_KIND) OFFSET

1.2 MPI_FILE_WRITE_AT

        MPI_FILE_WRITE_AT与MPI_FILE_READ_AT相对应,它从文件句柄fh对应的指定位置offset开始,将数据缓冲区buf中count个类型为datatype的数据写入到该文件中,其它status是返回的状态参数。

MPI_FILE_WRITE_AT(fh, offset, buf, count, datatype, status)
INOUT    fh            文件句柄
IN       offset        写入文件数据的起始偏移地址
IN       buf           将写入数据存放缓冲区的起始地址
IN       count         写入数据的个数
IN       datatype      写入数据的数据类型
OUT      status        写入操作完成后返回的状态信息

//c语言的说明
int MPI_File_write_at(MPI_File fh, MPI_Offset offset, void *buf, int count, MPI_Datatype datatype, MPI_Status *status)
//Fortran语言的说明
MPI_FILE_WRITE_AT(FH, OFFSET, BUF, COUNT, DATATYPE, STATUS, IERROR)
<type>  BUF(*)
INTEGER  FH, COUNT, DATATYPE, STATUS(MPI_STATUS_SIZE), IERROR
INTEGER(KIND=MPI_OFFSET_KIND) OFFSET

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/874944.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于SpringBoot的医院挂号预约管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 系统展示 【2025最新】基于JavaSpringBootVueMySQL的医院挂号…

港科夜闻 | 叶玉如校长出席2024科技+新质生产力高峰论坛发表专题演讲,贡献国家科技强国战略...

关注并星标 每周阅读港科夜闻 建立新视野 开启新思维 1、叶玉如校长出席“2024科技新质生产力高峰论坛”&#xff0c;做了题为“三个创新&#xff1a;培育和发展新质生产力、贡献国家科技强国战略”的主题演讲。该论坛于9月2日在香港召开。论坛围绕夯实基础科研、推动源头创新、…

『功能项目』管理器基类【38】

我们打开上一篇37单例模式框架的项目&#xff0c; 本章要做的事情是编写管理器基类 首先创建脚本&#xff1a;ManagerBase.cs using UnityEngine; public abstract class ManagerBase : MonoBehaviour{public virtual void Init() { } } public class ManagerBase<T> : …

Docker容器技术1——docker基本操作

Docker容器技术 随着云计算和微服务架构的普及&#xff0c;容器技术成为了软件开发、测试和部署过程中的重要组成部分。其中&#xff0c;Docker作为容器技术的代表之一&#xff0c;以其简便易用的特点赢得了广大开发者的青睐。 Docker允许开发者在轻量级、可移植的容器中打包和…

JAVA——方法

public static 返回值类型 方法名(参数){//方法体return 数据; } 一、定义与调用 public class demo9_12 {public static void main(String[] args) {// 调用myName();}//定义public static void myName(){System.out.println("Hello World");} } 运行 二、含参数…

类和对象(c++)

欢迎来到本期频道&#xff01; 类和对象 类定义&#xff1a;格式&#xff1a;类域&#xff1a;访问限定符友元内部类this指针静态与非静态成员关系类型转换六大默认成员函数&#xff08;C98&#xff09;1️⃣构造函数2️⃣拷贝构造函数浅拷贝与深拷贝 3️⃣赋值重载拷贝函数4️…

产线工控安全之防勒索病毒杀手锏

在当今数字化时代&#xff0c;数据安全已成为企业运营中不可或缺的一部分。勒索病毒和内部泄密事件的频发&#xff0c;使得企业必须采取更为严格的安全措施来保护其关键数据和运营系统。苏州深信达网络科技推出的MCK主机加固解决方案&#xff0c;正是为了应对这些挑战而设计的。…

Excel图片批量插入单元格排版处理插件【图片大师】

为了方便大家在图片的插入排版的重复工作中解放出来&#xff0c;最近发布了一款批量插入图片的插件&#xff0c;欢迎大家下载&#xff0c;免费试用。 这是图片的文件夹&#xff1a; 主要功能如下: 1&#xff0c;匹配单元格名称的多张图批量插入到一个单元格 该功能支持设置图…

vivo手机已删除的短信还能恢复吗?

虽然现在我们很少使用vivo手机的短信功能&#xff0c;但是我们偶尔还会通过vivo手机短信功能接收一些重要的信息。如果我们在清理垃圾短信的时候误删了vivo手机重要短信&#xff0c;该怎么恢复呢&#xff1f; 方法一&#xff1a;通过vivo云服务恢复 1、确保您已开启vivo云服务…

IP包头的总长度字段和UDP包头的长度字段之间的关系

IP包头的总长度字段和UDP包头的长度字段之间的关系&#xff0c;并通过实例加以说明。 IP包头的总长度字段 **总长度&#xff08;Total Length&#xff09;**字段是一个16位的字段&#xff0c;表示整个IP数据包的总长度&#xff0c;包括IP包头和数据部分。单位是字节。由于该字…

实操了 AI 大模型项目落地, 程序员成功转变为 AI 大模型工程师

前言 根据《2024 年全球人工智能行业报告》最新的数据显示&#xff0c;全球 AI 市场预计将以每年超过 40% 的速度增长&#xff0c;到 2030 年市值将达到数万亿美元&#xff0c;这也是预示着在接下来的十年到十五年里&#xff0c;人工智能将获得巨大的发展红利。 在过去的一年…

SQL的高级查询练习知识点中(day25)

1 学习目标 重点掌握聚合函数的使用重点掌握字段别名重点掌握分组查询的语法重点掌握having的使用方法了解子查询的语法重点掌握排序查询语法 2 排序查询 2.1 语法 SELECT要查询的东西 FROM表 WHERE 条件 ORDER BY 排序的字段|表达式|函数|别名 [ASC|DESC] ASC 升序&#…

某市第二届全民国防知识竞赛流程规则方案

1.勇往直前 &#xff08;1&#xff09;答题规则&#xff1a;参赛队员按顺序作答 &#xff08;2&#xff09;答题方式&#xff1a;根据大屏幕显示的题库&#xff08;一道单选题、一道多选题、一道判断题&#xff09;&#xff0c;采用依托答题系统进行现场答题。 &#xff08;3&…

mac电脑打包太多xcode项目导致硬盘满了的解决方法

主要针对于在文件夹中删除了很多无用的xode打包项目&#xff0c;但是硬盘还是占用的方法 1.删除各种没用的xcode项目 2.设置-通用-储存空间设置-开发者&#xff08;右键&#xff09;&#xff0c;选择xcode项目构建和索引、xcode缓存。点击删除

从用户反馈看相亲交友平台的设计缺陷及改进方向

相亲交友平台在现代社会中扮演着越来越重要的角色&#xff0c;尤其是在数字化时代&#xff0c;它们通过智能匹配算法帮助用户找到潜在的伴侣&#xff0c;并提供了一系列功能来增强用户体验开发h17711347205。以下是对相亲交友平台用户体验的一些分析&#xff1a; 用户界面设计…

C语言深入理解指针六(19)

文章目录 前言一、sizeof & strlensizeofstrlensizeof和strlen的对比 二、数组和指针笔试题解析一维数组字符数组二维数组 三、指针运算笔试题解析题目1题目2题目3题目4题目5题目6题目7 总结 前言 本篇都将是练习题&#xff0c;从而让你对指针的理解更上一层楼 一、sizeof …

RP2040 C SDK ADC功能使用

RP2040 C SDK ADC功能使用 &#x1f33f;RP2040 ADC功能说明文档&#xff1a;https://www.raspberrypi.com/documentation/pico-sdk/hardware.html#hardware_adc &#x1f4d7;RP2040 ADC介绍 SAR ADC500 kS/s (Using an independent 48MHz clock)12 bit (RP2040 8.7 ENOB, R…

网络工程师必知:高危端口大全,零基础入门到精通,收藏这一篇就够了

在计算机网络中&#xff0c;端口是主机与外界进行通信的通道。每个端口都可以看作是一条用于传输数据的虚拟线路。端口号是用于标识计算机网络服务的逻辑地址&#xff0c;它与IP地址共同构成了通信过程中的标识符。IP地址用于定位网络中的主机&#xff0c;而端口号则用于区分同…

如何通过食堂采购小程序端降低成本,提升效率?

随着数字化管理工具的普及&#xff0c;越来越多的食堂正在引入小程序来优化采购流程&#xff0c;减少成本和提升效率。食堂采购小程序端通过技术手段实现了自动化、智能化的管理方式&#xff0c;为管理者提供了极大的便利。本文将探讨如何利用技术手段开发一个高效的食堂采购小…

Excel文档的读取(1)

熟悉使用Excel的同学应该都知道&#xff0c;在单个Excel表格里想要分商品计算总销售额&#xff0c;使用数据透视表也可以非常快速方便的获得结果。但当有非常大量的Excel文件需要处理时&#xff0c;每一个Excel文件单独去做数据透视也会消耗大量的时间。就算使用Power Query这样…