& 引用形参 与 指针
2011-05-23 11:09
253 查看
#include <iostream> using namespace std; void freePtr1(int* p1) { //未释放内存前 -> p1 Address : 0012FDDC p1 value : 003429B8,在这里,p1它也是一个变量,既然是一个变量,那么它将会以值的传递,把外部变量p1传到栈内,在栈内产生一个地址:0012FDDC,当然,它的值不会变仍然是指向堆地址:003429B8 。 delete p1; //系统回收p1值的地址003429B8处的内存。 p1 = NULL;//对p1赋以NULL值即:00000000,注意:p1本身的地址并没有变,变的是p1的值。 //释放内存后 -> p1 Address : 0012FDDC p1 value : 00000000,出栈后,p1由于是一个临时对象,出栈后它会自动被视为无效。 } void freePtr2(int*& p2) { //未释放内存前 -> p2 Address : 0012FEC8 p2 value : 003429B8,p2是一个指针的引用,即引用指向指针,记住引用的特点:对引用的对象直接操作。所以它的地址和值与栈外的main()函数中,p2的值是同一个。 delete p2; //对p2所引用的指针进行释放内存,即:系统回收main()函数中 p2的值 003429B8 地址处的内存。 p2 = NULL;//对main()函数中p2的指针赋以NULL值。 //释放内存后 -> p2 Address : 0012FEC8 p2 value : 00000000,由于操作的对象都是main()函数中的p2,所以它将应用到原变量中。 } void main() { int *p1 = new int; //释放内存前-> p1 Address : 0012FED4 p1 value : 003429B8 freePtr1(p1); //释放内存后-> p1 Address : 0012FED4 p1 value : 003429B8 int *p2 = new int; //释放内存前-> p2 Address : 0012FEC8 p2 value : 003429B8 freePtr2(p2); //释放内存后-> p2 Address : 0012FEC8 p2 value : 00000000 system("pause"); }
相关文章推荐
- C++ 引用变量(十二)-- & b *b和C的传递指针形参一样效果
- 形参选择:值/引用/指针
- C++ Primer(第四版) 课后习题7.12 指针形参和引用形参比较
- 一、初级篇——指针(*)、取地址(&)、解引用(*)与引用(&)的区别
- 指针与引用的初始化&顶层底层const变量初始化问题
- &引用和&取地址
- 指针的引用(*&)
- C++&nbsp;引用&nbsp;指针&nbsp;智能指针&nbsp;拷贝构造
- C/C++函数形参传实参时值传递、指针传递、引用传递的区别
- [C++基础]019 指针和引用(int*、int&、int*&、int&*、int**)
- 详解C++中指针(*)、取地址(&)、解引用(*)与引用(&)的区别
- 细嚼慢咽C++primer(3)——引用形参,内联函数,重载函数,指向函数的指针
- "未将对象引用设置到对象的实例"异常的几种常见场合 【转载留着查找方面,哈哈】
- 指针作形参、二重指针作形参和先对指针进行typedef后用别名的引用作形参
- <C基础>数组和指针
- int *pa(指针)和int *&pa(指针的引用)的区别
- 【C/C++语法外功】传值&传引用&传指针
- 传值&传引用&传指针
- C/C++日常学习总结(第七篇)常引用&指针的理解
- 关于VC6.0 MSDEV.EXE-应用程序错误"0x5003eaed"指令引用的"0x0000000"内存错误的解决办法