博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
指针做为形参
阅读量:5129 次
发布时间:2019-06-13

本文共 981 字,大约阅读时间需要 3 分钟。

1,

 
void GetMemory(char *p, int num){    p = (char *)malloc(sizeof(char) * num);}void Test(void){	char *str = NULL;	GetMemory(str, 100);    // str 仍然为 NULL 	strcpy(str, "hello");   // 运行错误}

  

原因:编译器总是要为函数的每个参数制作临时副本,指针参数p的副本是 _p,编译器使 _p = p。如果函数体内的程序修改了_p的内容,就导致参数p的内容作相应的修改。这就是指针可以用作输出参数的原因。在本例中,_p申请了新的内存,只是把_p所指的内存地址改变了,但是p丝毫未变。所以函数GetMemory并不能输出任何东西。事实上,每执行一次GetMemory就会泄露一块内存,因为没有用free释放内存。

 

只修改了临时副本_p的内容,但p的内容没有修改

2:

void GetMemory2(char **p, int num){	*p = (char *)malloc(sizeof(char) * num);}void Test2(void){	char *str = NULL;	GetMemory2(&str, 100);  // 注意参数是 &str,而不是str	strcpy(str, "hello");  	cout<< str << endl;	free(str); }

  

 

3:指针的指针不好理解,可以用返回值传递

char *GetMemory3(int num){    char *p = (char *)malloc(sizeof(char) * num);    return p;}

  

4:动态内存会被自动释放掉么

(1)指针消亡了,不代表它所指的内存被自动释放

(2)内存被释放了,并不表示指针会消亡或者成了NULL指针了

5:产生野指针的原因:

1)指针没初始化,2)指针p,free或者delete后,p没有设置为NULL,仍然被认为是个合法的指针使用,3)指针操作超越了变量的作用范围

 

 

转载于:https://www.cnblogs.com/foreverlearn/archive/2012/04/23/2723556.html

你可能感兴趣的文章
mybatis调用存储过程,获取返回的游标
查看>>
设计模式之装饰模式(结构型)
查看>>
Swift3.0服务端开发(三) Mustache页面模板与日志记录
查看>>
EntityFrameWork 实现实体类和DBContext分离在不同类库
查看>>
autopep8
查看>>
GIT在Linux上的安装和使用简介
查看>>
基于C#编程语言的Mysql常用操作
查看>>
[转]: 视图和表的区别和联系
查看>>
Android 官方新手指导教程
查看>>
幸运转盘v1.0 【附视频】我的Android原创处女作,请支持!
查看>>
[51nod] 1199 Money out of Thin Air #线段树+DFS序
查看>>
Red and Black(poj-1979)
查看>>
安装 Express
查看>>
NOIP2013 提高组 Day1
查看>>
cocos2dx 3.x simpleAudioEngine 长音效被众多短音效打断问题
查看>>
存储(硬件方面的一些基本术语)
查看>>
观察者模式
查看>>
Weka中数据挖掘与机器学习系列之基本概念(三)
查看>>
Win磁盘MBR转换为GUID
查看>>
大家在做.NET B/S项目的时候多用什么设技术啊?
查看>>