在使用 valgrind 运行 MPI 程序时mpirun -np 3 valgrind test
,我注意到 malloc/calloc'ed 数组的地址有时对于不同的进程是相同的。这会让我相信 Valgrind 报告的地址不是绝对的,或者与物理内存地址不对应——这是有道理的,因为它使用自己的分配器。谁能证实这一点,或者告诉我我在这里缺少哪些琐碎的见解?谢谢你。
编码:
#include <stdio.h>
#include <stdlib.h>
#include <mpi.h>
#include <assert.h>
int main(int argc, char* argv[])
{
int rank, nproc;
/* first let MPI strip off its MPI stuff: */
MPI_Init(&argc, &argv);
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
MPI_Comm_size(MPI_COMM_WORLD, &nproc);
double* a;
int n = 40;
assert(a = calloc(n, sizeof(double)));
printf("Rank %d: Address of a = %p\n",rank,a);
free(a);
MPI_Finalize();
return 0;
}
示例输出:
Rank 0: Address of a = 0x6dad300
Rank 1: Address of a = 0x67a8800
Rank 2: Address of a = 0x67a8800