在向朋友教授动态内存分配时,我编写了一个简单的程序,其代码片段如下:
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 来自哪里?为什么它们总是一样的?我希望它们不是垃圾,并且必须具有某种意义..我无法推断。请帮忙。