2

在使用 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
4

1 回答 1

0

在现代处理器/操作系统中,内存被映射到程序的进程空间中。该程序没有概念(或兴趣)它正在使用的空间的实际物理内存地址——只有设备驱动程序真正需要。

于 2013-07-11T16:36:49.783 回答