指针作形参,需要注意的问题。

时间:2022-07-28
本文章向大家介绍指针作形参,需要注意的问题。,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

最近在写链表的时候,定义了一个指针,当指针作为函数参数传参的时候出现了问题: 定义了一个空指针: 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 );
 

读到这里,不知道读者有没有想到一个常见的例子,用一个函数交换两个变量的值,变量作参数,这是值传递,我们知道函数内对传递过来的值作任何操作,对原值没有任何影响,于是我们引入指针,引入变量地址来解决交换,现在也一样,我们想改变一级指针,自然就需要二级指针来解决问题,所以,你明白了吗。

如有错误,欢迎指正批评,欢迎讨论。 每文一句:人活着,便注定了这辈子的奔波与劳累。有太多的选择与无数的十字路口,这些太多的背后,我们只能选择让心去承受,学会沉淀。