MPICH 中读取文件的问题

在使用MPI进行文件读取时遇到错误,原因是MPI只能处理二进制文件。通过将文本文件转换为二进制文件后,问题得到解决。在转换过程中,需要注意将数据先读入一维数组,而非二维或三维数组,以避免读取时出现异常。总结关键点:MPI只读二进制文件,文本转二进制需先读入一维数组。
摘要由CSDN通过智能技术生成
用MPI I/O读取文件时,读出的数字不正确。为了验证错误,写了一个简单程序。

想要读取的数据 feifei.dat:

2 3 4 5 6

读文件的程序:
#include<iostream>
#include<string.h>
#include "mpi.h"
using namespace std;
int main(int argc,char **argv){

	int a=0;
	int rank;
	MPI_Status status;
	MPI_Init(&argc,&argv);
	MPI_Comm_rank(MPI_COMM_WORLD,&rank);
	MPI_File dv;
	MPI_File_open(MPI_COMM_WORLD,"feifei.dat",MPI_MODE_RDONLY,MPI_INFO_NULL,&dv);
	MPI_File_read_ordered(dv,&a,1,MPI_INT,&status);

	cout<<"My rank = "<<rank<<" reads : "<<a<<endl;
	MPI_Finalize();
}


读取错误结果:


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值