1

在问这个问题之前,我提到了这个这个这个SO 帖子:

在向朋友教授动态内存分配时,我编写了一个简单的程序,其代码片段如下:

matrix = (int**) malloc (sizeof(int*) * m);
for (i = 0; i < m; ++i)
matrix[i] = (int*) malloc (sizeof(int) * n);

for (i = 0; i < m; ++i)
  for (j = 0; j < n; ++j)
      matrix[i][j] = rand() % 100; /*some random value*/


for (i = 0; i < m; ++i)
{
  for (j = 0; j < n; ++j)
  {
      printf("(%8u)%-5d", &matrix[i][j], matrix[i][j]);
  }

  /* Print element just after the first row*/
  printf("(%8u)%-5d", matrix[i] + n, *(matrix[i] + n));

  /* Print second NEXT element just after the first row*/
  printf("(%8u)%-5d", matrix[i] + n + 1, *(matrix[i] + n + 1));
}

当我运行这个程序时

unmesh@unmesh-laptop:~/teaching/C/Day3$ ./matrix
Enter number of rows: 3
Enter number of columns: 3

(141189144)1    (141189148)2    (141189152)3    **(141189156)17**   (141189160)2    

(141189160)2    (141189164)3    (141189168)4    **(141189172)17**   (141189176)3    

(141189176)3    (141189180)4    (141189184)5    (141189188)135105(141189192)0 

我对 17 的值很好奇。如果我没记错的话,在这个调用中有三个 malloc 调用,所以内存可能不是可以观察到的连续的。但是我使用m=n=4 或 m=n=5运行程序,然后我可以在每行之后看到值25 。对于m=n=6 和 m=n=7 ,观察到值33 。

更有趣的是,当 n 为奇数时(n=3 / n=5 ..),该值会在行结束后立即存储。m=n=3 时的示例行

Values  1        2       3       17  
Address 100      104    108     112  

Next row starts from 116

当 n 为偶数时,存储在 m=n=2 时的 4 字节示例行之后

Values  1        2       0       17  
Address 100      104    108     112  

Next row starts from 116

问题是这些值 17/25/33 来自哪里?为什么它们总是一样的?我希望它们不是垃圾,并且必须具有某种意义..我无法推断。请帮忙。

4

1 回答 1

2

您会看到内部簿记信息 malloc 存储以跟踪已分配的块。此信息的精确性质和大小因系统而异,但通常情况下 malloc 会将请求的大小四舍五入,以便在结合其簿记信息时,生成的块是通常所需的最大对齐的倍数你的机器。在您的情况下,对齐看起来像是 8 个字节(两个整数),导致您看到的偶数/奇数行为。您看到的 17/25/33 值可能是已分配块的大小(包括填充和大小信息),其中最低位设置为指示正在使用的块。

于 2013-03-08T18:46:16.943 回答