假设以下 MPI 代码。
MPI_Comm_Rank(MPI_COMM_WORLD, &rank);
if (rank == 0){
MPI_Send(a, count, MPI_CHAR, 1, 0, MPI_COMM_WORLD);
MPI_Send(b, count, MPI_CHAR, 1, 0, MPI_COMM_WORLD);
}
else if (rank == 1){
MPI_IRecv(a, 1, MPI_CHAR, 0, 0, MPI_COMM_WORLD, &req);
MPI_Recv(b, count, MPI_CHAR, 0, 0, MPI_COMM_WORLD);
MPI_Wait(&req, &status);
}
说第一个MPI_Send(a, count, ...)
不会阻塞,即使它的匹配MPI_IRecv(a, 1, ...)
只从缓冲区中读取一个元素是正确的吗?
另外,由于没有对缓冲区进行读/写操作a
,即使MPI_Wait
在之后没有直接调用,进程 1 是否也不会阻塞MPI_IRecv
?
谢谢。