0

在下面的乒乓程序中,rc变量有什么用?它不断更新,但从未使用过。
加上做MPI_Get_Count()什么?


#include "mpi.h" 
#include <stdio.h>

int main(int argc, char * argv []) 

int numtasks, rank, dest, source, rc, count, tag=1;  
char inmsg, outmsg; 
MPI_Status Stat ;

MPI_Init (&argc,&argv); 
MPI_Comm_size (MPI_COMM_WORLD, &numtasks); 
MPI_Comm_rank (MPI_COMM_WORLD, &rank);

if (rank == 0) {
  dest = source = 1;outmsg=’x’;
  rc = MPI_Send (&outmsg, 1, MPI_CHAR, dest, tag, MPI_COMM_WORLD);
  rc = MPI_Recv (&inmsg, 1, MPI_CHAR, source, tag, MPI_COMM_WORLD, &Stat);
} 
else if (rank == 1) {
  dest = source = 0;outmsg=’y’;
  rc = MPI_Recv (&inmsg, 1, MPI_CHAR, source, tag, MPI_COMM_WORLD, &Stat);
  rc = MPI_Send (&outmsg, 1, MPI_CHAR, dest, tag, MPI_COMM_WORLD);
}

rc = MPI_Get_count (&Stat, MPI_CHAR, &count);
printf("Task %d: Received %d char(s) from task %d with tag %d \n", rank, count, Stat.MPI_SOURCE,Stat.MPI_TAG); 
MPI_Finalize ();
}
4

1 回答 1

0

MPI_Get_count“输出”部分中的文档回答了这一点,该部分位于该链接页面的下方。

至于rc,这是我能提供的最好的解释,无法访问此代码的作者或任何相关注释。C 绑定中的所有 MPI 例程都返回错误代码。一些编译器会检查是否有人在地板上丢弃返回值,因为这可能表明代码中有错误,并在他们看到发生的情况下生成警告。因此,为了防止出现这些警告,此代码将返回值分配给变量rc

也就是说,许多编译器也会警告设置一个从未使用过的变量,这里就是这种情况。告诉编译器“是的,我知道我忽略了这个返回值,别管我”的成语是(void)function_call(foo, bar, baz);(即将返回值转换为void)。这在调用真正应该检查返回值的函数时最常见,例如write(). 在每个 MPI 调用上写它而不是消除一个有问题的警告会相当难看。

于 2012-04-20T18:50:56.743 回答