指针的解引用(*)疑点分析
一、指针变量
在c语言中,每个变量有两个重要数据:地址和“内容”,纵然指针也不例外。指针的“内容”是别的变量的地址,指针的地址是指针本身在内存中的地址。
指针有引用(&)和解引用(*)两种操作,此处不对引用详细说明,解引用是一个权限很高的操作
二、解引用(*)未初始化的指针;
错误的用法:
#include<stdio.h>
int main()//错误的用法
{
int *p;//定义了一个int型指针
int a = 1;
*p = a;//将a的值赋值给*p
printf("%p\n",p);
return 0;
}
在上述代码中,已知p是一个 int型指针,则*p应当是一个int型数据,将int类型a的“内容”赋值给 *p,看起来很合理。可问题在于 p是未初始化的,系统只分配了存储指针本身的内存(即p有地址,但p无“内容”,或者说“内容”为NULL),并未分配存储数据的内存(即p的“内容”所指向的内存)。对于程序来说,p=NULL,对 *p赋的值是不知道存储在何处的,其后果是不可预测的。所以使用指针前,必须先用已分配的地址初始化它!
#include<stdio.h>
int main()//成功的代码
{
int *p;//p有了地址,其"内容"为 NULL
int m = 0;//m有了地址和"内容"
int a = 1;
int p = &m;//p获取了"内容",现在 p又有地址,又有"内容"。
*p = a;
/*
此时由于 p有了"内容",且其"内容"是一个已分配
的地址,对其"内容"解引用可以找到另一个"内容"
此处等同于 m = a
*/
printf("%p,%p\n",pp,p);
return 0;
}
再来分析更复杂的二级指针
#include<stdio.h>
int main()//错误的代码
{
int m = 1;
int **pp;
int *p_array[10] = {&m};
*pp = p_array+5 ;
printf("%p,%p,%p\n",pp,p_array[0],&m);
return 0;
}
其实同理,第7行中试图对未初始化的指针解引用,自然不能成功运行。