码迷,mamicode.com
首页 > 其他好文 > 详细

函数入参使用指针和引用的区别

时间:2018-02-28 12:59:55      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:ase   获取   总结   引用   全局变量   bsp   mes   nbsp   工具   

最近做一个工具,在整改函数时需要给一个全局变量赋值

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上

 

通过以上可以总结出:尽量少用引用作为左值,如果需要通过函数参数来赋值(出参),最好使用临时指针变量来获取地址,再赋值给需要的变量

函数入参使用指针和引用的区别

标签:ase   获取   总结   引用   全局变量   bsp   mes   nbsp   工具   

原文地址:https://www.cnblogs.com/charlieroro/p/8482783.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!