写在前面:
大家好,我是 花狗Fdog ,来自内蒙古的一个小城市,目前在泰州读书。
很感谢能有这样一个平台让我能够在这里分享所学所感。
我喜欢编程,喜欢代码,喜欢去做一个程序员。
努力学习,争取多年后,给亲人更好的生活。
QQ/WX:2506897252 欢迎交流。
最近在写链表的时候,定义了一个指针,当指针作为函数参数传参的时候出现了问题:
定义了一个空指针:
int * end=NULL;
指针作为参数,目的可以指向申请的内存:
void func(int * P)
{
int * P_1 = (int *)malloc(sizeof(int));
P=P_1;
}
但是当该函数被调用后,该指针end依旧为NULL,通过上述例子,我们可以看到,一级指针作为函数参数时,在函数体内对指针做变动,当函数被调用结束后,原始指针不会产生任何变化。
但是指针作为函数值返回时则没有问题:
int * P = func();
int * func()
{
int * P_1 = (int *)malloc(sizeof(int));
return P_1;
}
使用二级指针作参数也是没有问题的,
int * P=NULL;
void func(int **P)
{
int * P_1 = (int *)malloc(sizeof(int));
(*P)=P_1;
}
func(&P);
上述写法存在问题,感谢评论区指正,修改为:
int ** P=NULL;void func(int **P)
{
int * P_1 = (int *)malloc(sizeof(int));
(*P)=P_1;
}func( P );
读到这里,不知道读者有没有想到一个常见的例子,用一个函数交换两个变量的值,变量作参数,这是值传递,我们知道函数内对传递过来的值作任何操作,对原值没有任何影响,于是我们引入指针,引入变量地址来解决交换,现在也一样,我们想改变一级指针,自然就需要二级指针来解决问题,所以,你明白了吗。
如有错误,欢迎指正批评,欢迎讨论。
每文一句:人活着,便注定了这辈子的奔波与劳累。有太多的选择与无数的十字路口,这些太多的背后,我们只能选择让心去承受,学会沉淀。