以mpi分散

这是mpi scatter的代码:

#include  #include  int a[10]={1,2,3,4,5,6,7,8,9,10}; int b[1]; int main(int argc, char *argv[]) { int rank; MPI_Init(&argc, &argv); MPI_Comm_rank(MPI_COMM_WORLD, &rank); MPI_Barrier(MPI_COMM_WORLD); if(rank ==0){ MPI_Scatter(a,1,MPI_INT,b,1,MPI_INT,0,MPI_COMM_WORLD); } MPI_Barrier(MPI_COMM_WORLD); printf("\n%d from rank=%d\n",b[0],rank); MPI_Finalize(); return 0; } 

我想要输出如下:

1等级0
2级来自1级
排名2的3

但我得到了

1等级0
排名第1的0
等级2的0
等级3的0
排名第4的0

MPI_Scatter()是一个集合操作,因此它必须由通信器的所有队列调用。

摆脱if (rank == 0) ,你会没事的。

请注意,在您的示例中,发送缓冲区足够小并且不会导致任何挂起。