/*i am doing in main function*/
int main(void)
{
//allocating memory
double** p = malloc(ROWS * sizeof(double*));
int i, j;
for (i = 0; i < ROWS; i++)
p[i] = malloc(COLS * sizeof(double));
// set every array element as 1
for (i = 0; i < ROWS; i++)
for (j = 0; j < COLS; j++)
p[i][j] = 1;
//print array element
for (i = 0; i < ROWS; i++)
{
for (j = 0; j < COLS; j++)
printf("%f ", p[i][j]);
printf("\n");
}
make5(ROWS, COLS, p);
//here why this is changed???
for (i = 0; i < ROWS; i++)
{
for (j = 0; j < COLS; j++)
printf("%f ", p[i][j]);
printf("\n");
}
return 0;
}
/* and changing value in below function */
int make5(int r, int c, double **d)
{
int i, j;
/*changing value of received array*/
for (i = 0; i < r; i++) {
for (j = 0; j < c; j++) {
d[i][j] = 5;
}
}
return 0;
}
最佳答案
您按值传递了指针 - 但这只是一个指针。这说明了包含各个值的内存在哪里。您的 make5
函数实际上根本不会更改参数 (d
) 的值 - 类似于:
d = malloc(...);
按值传递是指将参数值(本例中为p
)的更改简单地复制到参数(d
)。函数的调用者看不到对参数的进一步更改。这很好,因为参数没有任何变化。相反,您的函数会更改 d
引用的内存内容。这与 p
引用的内存相同,因此在调用函数后打印值时您会看到变化。 (在这种情况下,实际上有两级间接,因为 p
的值表示进一步的指针在哪里,但原理是相同的。)
假设我将街道地址写在一张纸上 (p
)。我复印那张纸,然后给你,称副本d
。我不在乎你对这张纸做了什么 - 但如果你访问我的房子并将门漆成不同的颜色,我会看到,因为我仍然有街道地址我的房子在我的纸上。这张纸不包含我的房子——它只是告诉我如何到达我的房子。同样,指针并不包含所有单独的值 - 它只是告诉您如何获取它们。
关于c - 在c中传递双指针作为值传递,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25637254/