#include <stdio.h>
#include <stdlib.h>//动态分配内存相关函数所有的头文件。
//指针变量其实也是一般的变量(它自己的内存地址也如同其它变量一样,只不过它的值和其它普通变量不一样,是一段内存的首地址),且当指针指向用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.