• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

C++中的传值与传址

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

在指针的传递中,也涉及到传值与传址的问题。下面通过一个函数进行说明。

代码如下:

bool openBinary(uchar* buffer)
{
    long lSize = 1024;
    buffer = (uchar*)malloc(sizeof(uchar)*lSize);
    return true;
}
int main(int agrc, char *agrv[]){
  uchar *buffer_0 = NULL;
  openBinary(buffer_0);
  return 0;
}

在上面的代码中,执行过openBinary函数后,buffer_0依然是一个空指针。

原因是因为执行openBinary函数时,函数生成了一个值与buffer_0相同的uchar*临时变量buffer,在分配内存前,临时变量buffer和buffer_0的值相同,但在分配内存后,动态分配的内存地址赋值给了临时变量buffer。从此刻开始,临时变量buffer的值和buffer_0的值就不一样了,buffer_0依然是一个空指针,而临时变量buffer指向了新分配内存的首地址。openBinary函数执行完毕后,临时变量buffer被销毁,成为buffer_0的一个过客,而buffer曾指向的内存也不知所向,最后buffer_0一无所获。

如果像让buffer_0最终获得内存,在函数调用时就需要传址而非传值。

代码如下:

bool openBinary(uchar* &buffer)
{
    long lSize = 1024;
    buffer = (uchar*)malloc(sizeof(uchar)*lSize);
    return true;
}
int main(int agrc, char *agrv[]){
  uchar *buffer_0 = NULL;
  openBinary(buffer_0);
  return 0;
}

上述代码中,openBinary函数中传入了buffer_0的引用,在动态内存的分配中,buffer_0是真实参与其中的,函数执行过后,buffer_0是可以获得内存的。

最后注意,内存使用完毕后要进行释放。

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C++内存对齐发布时间:2022-07-14
下一篇:
C#WebAPI实现上传功能WebApi实现单个文件的上传下载发布时间:2022-07-14
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap