在这个小代码示例中,我在 MPI(使用 C++)中发现了一些意外行为:
int rank, size;
MPI_Init(&argc, &argv);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
MPI_Comm_size(MPI_COMM_WORLD, &size);
if(rank == 1) {
int *sendDone = (int*)malloc(sizeof(int));
*sendDone = 1;
MPI_Ssend(sendDone,1,MPI_INT, 0, 1,MPI_COMM_WORLD);
foo();
} else {
int *rcvDone = (int*)malloc(sizeof(int));
bar();
while(*rcvDone != 1) {
MPI_Recv(rcvDone,1,MPI_INT, MPI_ANY_SOURCE, 1, MPI_COMM_WORLD, MPI_STATUS_IGNORE);
}
cout << *rcvDone << endl;
}
MPI_Finalize();
它使用以下命令编译和运行:
mpic++ sim.cc -o sim
mpirun -n 2 ./sim
代码应按以下顺序执行:
bar();
foo();
因为在执行bar()之后 Process #0 开始接收。但实际上,foo()有时会在bar()完成之前开始。有人可以向我解释一下并解决问题吗?