把指针作为函数形参的一般目的与意义在于:
能在函数内部修改指针所指对象的值
何时需要用“ 指针的指针 ”作为 函数形参?
当你需要在函数内部修改指针的指向时
void f(int * pk); void f_(int * *pk); int data =6; int *p=&data;
p=data的地址
&p=p的地址(即地址的地址)
void f(int * pk);
f(p) -> 把p传到f函数时,pk=p;pk获得了data的地址,故可用pk修改data。然而pk并不知道p的地址,故无法修改p的值即p的指向。这里的本质还是值传递,是data的地址被拷贝给了pk
f(*p): 函数内部可改变p指向的变量的值,但不可改变源p的值,即不可改变p的指向
f(**p): 函数内部可改变p指向的变量的值,也可改变源p的值,即可改变p的指向
...略显抽象
总结来说:
void f(int * pk);
void f_(int * *pk);
所谓形参都是值传递,都是实参的副本。若要通过函数内部修改外部的值,单单使用pk是一定不够的,因为pk不过是函数内的一个临时副本,任何直接对pk的赋值都不会影响外部,但*p或**p则会改变外部的值,因为他们代表的都是真实的外部变量。而**p中的p更深层次,控制权更多