void myFunction(int* ptr) {
int x = 10;
ptr = &x; // 这一步只是改变了ptr指针自己的值,使它指向了新的内存地址(即x的地址)
}
int main() {
int y = 20;
int* py = &y;
printf("Before function call: *py = %d\n", *py); // 输出:Before function call: *py = 20
myFunction(py);
printf("After function call: *py = %d\n", *py); // 输出:After function call: *py = 20
return 0;
}
在main
函数中,我们创建了一个名为py
的指针,它指向int
类型变量y
。我们将py
传递给myFunction
函数。
在myFunction
函数中,ptr
是形参,它被初始化为指向py
所指向的内存区域。但是当我们把ptr
指向了一个新的地址(即x
的地址)时,这个改变不会影响到py
指针,因为ptr
和py
是两个不同的指针,它们各自拥有自己的存储空间。
这就是为什么在函数内部更改形参指针的值(即让它指向一个新的地址)时,实际参数的ptr地址不会受到影响的原因。
py指向地址1,形参ptr经过传参初始化也指向地址1,但是你改ptr的指向,并不会影响函数外部的py