1、内存分配函数都在stdlib.h头文件中,所以要包含该头文件。
#include <stdio.h>
#include <stdlib.h>
int main()
{
int * temp;
temp = (int *)malloc(sizeof(int));//写法二:temp = (int *)calloc(1,sizeof(int));
printf("(temp变量本身的地址): %p\n",&temp);
printf("(temp所指向的地址): %p\n",temp);
scanf("%d",temp);
printf("给temp所指向内存赋值以后,temp所指向地址的内容(该块内存上的值): %d\n",*temp);
free(temp);
puts("\n=======free(temp)过后!========");
printf("(temp变量本身的地址): %p\n",&temp);
printf("(temp所指向的地址): %p\n",temp);
printf("temp所指向地址的内容(该块内存上的值): %d\n",*temp);
//创建指针变量后,那么该指针变量自身肯定会有一个不变的地址
//free()函数释放掉的是内存分配函数给分配的内存,而指针变量自身的地址肯定是不会变化的。
//但是free过后,该指针所指向的的内存被释放了,内存中的值消失了
//但是指针所指向的内存地址还是那个原来指向的内存地址,因为该内存地址是在内存中固定不变的。
//指针所指向的内存地址上面没有值,从而指针解引用后结果不可预料。(见两张运行截图的最后一行输出)
return 0;
}
2、两次运行看变化.
这也间接告诉我们,指针的值是它所指向数据对象地址的地址值(通过对数据对象取地址再赋值给该指针变量)或通过动态内存分配得来得地址值。
指针类型跟基本数据类型很像。(就像声明一个基本数据类型(如int类型)的变量,被声明后该变量在内存中的地址是不变的,但是变量本身的值是可以变的)。指针变量也是如此。