#include#include //动态分配内存相关函数所有的头文件。//指针变量其实也是一般的变量(它自己的内存地址也如同其它变量一样,只不过它的值和其它普通变量不一样,是一段内存的首地址),且当指针指向用new malloc动态分配内存时.需要人为的释放free delete等.int *p1;//指针变量自己有固定的内存地址int *p2;void PointerTest();int main(){ PointerTest(); int c=10; int d=20; printf("出了a的作用范围:\n"); printf("&p1=%d,p1=%d,*p1=%d\n",&p1,p1,*p1);//p1所指向的内存没有被释放,值也不会改变 printf("&p2=%d,p2=%d,*p2=%d\n",&p2,p2,*p2);//在外部调用时。因为变量的内存已经被释放,不过全局指针变量p2仍指向刚刚a所占的内存。这段内存的值不可知,有可能不变,有可能被系统去除 free(p1);//释放p1所指向的一段内存 但是p1的值没有改变,仍是那段内存的首地址。 printf("主动释放了p1指向的内存:\n"); printf("&p1=%d,p1=%d,*p1=%d\n",&p1,p1,*p1); p1=NULL;//清空指针的值,空指针,不指向任何内存地址。 printf("清空p1的值:\n&p1=%d,p1=%d\n",&p1,p1);//这时如果再*p1会报错,因为*p1是p1所指向的内存的值.此时p1已经不指向任何内存 return 0;}void PointerTest(){ int a=10; p1=(int *)malloc(sizeof(int));//动态随机分配一段内存,该内存属于堆,需要人为释放。 p2=&a;//指向a变量 p2的值是a变量的地址,a变量属于动态存储,放在动态存储区属于栈,自动释放。 *p1=1;//操作指针变量实际上是操作它所指向的内存区域。对指针本身没有影响。除了改变p1的指向。 printf("函数内部(a的作用范围):\n"); printf("&p1=%d,p1=%d,*p1=%d\n",&p1,p1,*p1); printf("&p2=%d,p2=%d,*p2=%d\n",&p2,p2,*p2);}
程序运行结果: 函数内部(a的作用范围): &p1=4210768,p1=7088880,*p1=1 &p2=4210752,p2=2686700,*p2=10 出了a的作用范围: &p1=4210768,p1=7088880,*p1=1 &p2=4210752,p2=2686700,*p2=1967623381 主动释放了p1指向的内存: &p1=4210768,p1=7088880,*p1=7081728 清空p1的值: &p1=4210768,p1=0 Process returned 0 (0x0) execution time : 0.664 s Press any key to continue.