3、C语言中一般类型的指针变量细解

#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.

 

你可能感兴趣的:(C语言)