0
指望这可能是一件微不足道的小事,但:缓冲区大小大于在MPI_SEND
可以在底层数组的大小比数参数不再与缓冲区指针在MPI_SEND(...)调用一起发送?
至于MPI_Recv(...)我发现明确声明这是合法的来源(即缓冲区大于消息)。
另外,它似乎是确定,当我编译,因为我获得以下任何错误信息输出运行下面的程序
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <mpi.h>
int main(int argc, char **argv){
int i;
MPI_Init(&argc, &argv);
int world_rank;
MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);
int world_size;
MPI_Comm_size(MPI_COMM_WORLD, &world_size);
if(world_size != 2) {
printf("You're supposed to use exactly 2 processes, dude!\n");
MPI_Abort(MPI_COMM_WORLD, 0);
}
int *ids = (int*)(malloc(10*sizeof(int)));
if(world_rank == 0) {
for(i=0; i<10; i++)
ids[i]=i+1;
MPI_Send(ids, 5, MPI_INT, 1, 0, MPI_COMM_WORLD);
}else{
for(i=0; i<10; i++)
ids[i]=20-i;
MPI_Recv(ids, 5, MPI_INT, 0, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE);
}
for(i=0; i<10; i++)
printf("me %d %d %d\n",world_rank,i,ids[i]);
free(ids);
MPI_Finalize();
return 0;
}
:
me 0 0 1
me 0 1 2
me 0 2 3
me 0 3 4
me 0 4 5
me 0 5 6
me 0 6 7
me 0 7 8
me 0 8 9
me 0 9 10
me 1 0 1
me 1 1 2
me 1 2 3
me 1 3 4
me 1 4 5
me 1 5 15
me 1 6 14
me 1 7 13
me 1 8 12
me 1 9 11
但我想有因为我仍然是一个新手...
它不仅安全:这是通常做的事情。例如,当您必须在阵列的边界上发送/ recv幻像数据时。或者您发送一排二维数组。此外,MPI支持使用MPI数据类型发送/接收稀疏缓冲区 - 例如,发送一个2D数组的列。所以不用担心 - 你的代码是可以的。 – Sigismondo