函数入参使用指针和引用的区别
最近做一个工具,在整改函数时需要给一个全局变量赋值
RadixNode *g_pstRootBase
赋值的来源为已定义的结构体:TreeSet treeSet = {0}中的trSet->tNameSet[i].tName地址(其中i为变量。
以下是trSet结构体的定义:
typedef struct tagTreeName
{
RadixNode *tName;
char *fName;
}TreeName;
typedef struct tagTreeSet
{
TreeName tNameSet[MAX_SYMBOL_TREE_NUM];
int realNum;
}TreeSet;
因为其他处理的需要,写了个函数,函数原型为:
int setTreeName(TreeSet *trSet, RadixNode **tName)
想通过第二个入参tName将trSet->tNameSet[i].tName的地址赋值给g_pstRootBase(函数有删减)
传参方式为:setTreeName(&trSet, &g_pstRootBase),内部处理如下
int setTreeName(TreeSet *trSet, RadixNode **tName)
{
tName = &trSet->tNameSet[i].tName;
}
}
但在调试的时候发现g_pstRootBase并没有赋值成功,即g_pstRootBase仍然是初始值
分析一下才发现&g_pstRootBase的意思是的g_pstRootBase地址,并不是一个真正的指针变量,可以认为就是一个地址常数!
修改函数中对g_pstRootBase的赋值方式如下:
int setTreeName(TreeSet *trSet, RadixNode **tName)
{
*tName = (RadixNode*)(&trSet->tNameSet[i].tName);
}
}
这样程序就可以正常运行了,即将&trSet->tNameSet[i].tName的地址赋值到地址*tName上
通过以上可以总结出:尽量少用引用作为左值,如果需要通过函数参数来赋值(出参),最好使用临时指针变量来获取地址,再赋值给需要的变量
上一篇: MongoDB 搭建可复制群集
推荐阅读
-
JavaScript学习和使用之函数声明和函数表达式的区别
-
Java中构造方法、空指针异常现象、基本数据类型和引用数据类型作为参数传递的区别
-
c语言:sizeof的使用,其不是函数,是一个操作符关键字,定义一个数组arr,输出arr和&arr的区别
-
详谈C++引用&和指针在作为形参时的区别
-
perl中chomp的使用介绍(chop和chomp函数区别)
-
R语言中cbind、rbind和merge函数的使用与区别
-
函数入参使用指针和引用的区别
-
vue router使用query和params传参的使用和区别
-
深入讲解Go语言中函数new与make的使用和区别
-
JS函数传参时值传递与引用传递的区别