C/C++ 指针做参数 堆内存分配
2015-11-19 16:27
197 查看
from /article/1711109.html\
1、指针参数分配堆内存问题
注意:像以上程序的分配方法是有问题的,程序运行结果str仍然为NULL,而且程序运行一次会产生一次内存泄露。
原因:问题出在函数GetMemery()函数中,编译器总是要为函数的每个参数制作临时副本,指针参数p的副本是_p。如果函数日内的程序修改了
_p指向的内容,就导致参数p指向的内容也被做了相应的修改(以为他们指向同一块内存空间)。这就是指针可以做输出参数的原因。但是在本例中
,_p申请了新的内存,只是把_p本身的值改变了,即指向了新的内存空间,但是p本身丝毫没变(即修改了_p本身的值,而不是_p指向的对象)。
所以函数GetMemory()并不能输出任何东西。
办法:如果一旦要用指针参数去申请内存,那么应该使用“指向指针的指针”或”指向指针的引用“或使用返回值的办法。
如下所示:
1、指针参数分配堆内存问题
void GetMemory(char *p,int num) { p = new char[num]; } int _tmain(int argc, _TCHAR* argv[]) { char *str = NULL; GetMemory(str,100); strcpy(str,"hello"); }
注意:像以上程序的分配方法是有问题的,程序运行结果str仍然为NULL,而且程序运行一次会产生一次内存泄露。
原因:问题出在函数GetMemery()函数中,编译器总是要为函数的每个参数制作临时副本,指针参数p的副本是_p。如果函数日内的程序修改了
_p指向的内容,就导致参数p指向的内容也被做了相应的修改(以为他们指向同一块内存空间)。这就是指针可以做输出参数的原因。但是在本例中
,_p申请了新的内存,只是把_p本身的值改变了,即指向了新的内存空间,但是p本身丝毫没变(即修改了_p本身的值,而不是_p指向的对象)。
所以函数GetMemory()并不能输出任何东西。
办法:如果一旦要用指针参数去申请内存,那么应该使用“指向指针的指针”或”指向指针的引用“或使用返回值的办法。
如下所示:
void GetMemory(char **p,int num) { *p = new char[num]; } int _tmain(int argc, _TCHAR* argv[]) { char *str = NULL; GetMemory(&str,100); strcpy(str,"hello"); cout << str << endl; }
相关文章推荐
- C++ stringstream介绍,使用方法与例子
- C++ 09原型模式
- C语言用一维数组打印杨辉三角(原:无意中想到)
- 二叉搜索树的查询、插入与删除操作(Binary Search Tree, Search, Insert, Delete)(C++)
- 程序的内存布局
- 获得当前登录系统的用户名
- c语言实现动态顺序表
- C语言笔试面试总结(网上搜集)
- C++实现含有中文字符串逆序
- c++虚函数实现机制及内存模型
- 简单分析C语言中指针数组与数组指针的区别
- C语言中的回调
- c++中switch语句的使用问题
- C语言中下标与指针的转换以及指向指针的指针的例子
- Composite(组合)设计模式
- 标准C++中的string类的用法总结
- C语言函数之可变参数原理:va_start、va_arg及va_end !!!!!!和printascii在kernel启动前的应用
- Gamma原理及快速实现算法(C/C++)(转)
- 学习C++ vector(摘录)
- 学习笔记6-C语言内存管理+构造类型