一个数组,若其元素均为指针类型数据,称为指针数组,也就是说,指针数组中的每一个元素都存放一个地址,相当于一个指针变量。下面定义一个指针数组:int *p[4] 注意不要写成int (*p)[4].
可以分别定义一些字符串,然后用指针数组中的元素分别指向各字符串,在name[ 0]中存放字符串"Follow me"的首字符的地址。name[1]中存放字符串"BASIC"的首字符的地址……如果想对字符串排序,不必改动字符串的位置,只须改动指针数组中各元素的指向(即改变各元素的值,这些值是各字符串的首地址)。这样,各字符串的长度可以不同,而且移动指针变量的值(地址)要比移动字符串所花的时间少得多。
指针数组例如:char *name[]={“hello”,”basic”,”great wall”};
实际上,在先前的字符型指针我们就已经讲过,指针变量存储的不是整个字符串,而是它的首地址,这里也同理
指向指针的指针
定义为:int **p2;
p的前面有两个*号。我们知道,*运算符的结合性是从右到左,因此**p相当于*( * p),显然*p是指针变量的定义形式。如果没有最前面的* ,那就是定义了一个指向字符数据的指针变量。现在它前面又有一个*号,即 char **p。可以把它分为两部分看,即:char *和( * p),后面的(* p)表示p是指针变量,前面的char*表示p指向的是char *型的数据。也就是说, p指向一个字符指针变量(这个字符指针变量指向一个字符型数据)。如果引用*p,就得到p所指向的字符指针亦量的值,如果有:
p=name+2;
printf(" % d\n",* p); printf(" %s\n”,* p);
p指向指针数组,name是指针数组的首地址,name+i即为name[i]的地址,第一个printf输出的是name[2]的地址值,而第二个printf输出的是name[2]指向的值即BASIC(%s看的是地址)
举例:
#include<stdio.h>
int main()
{
int a[5] = { 1,2,3,4,5 };
int* num[5] = { &a[0],&a[1],&a[2],&a[3],&a[4] };
int** p, i;
p = num;//定义p为&num[0],而Num[0]又指向a
for (i = 0; i < 5; i++)
{
printf(" %d", **p);
p++;
}
printf("\n");
return 0;
}
程序分析:程序中定义p是指向指针型数据的指针变量,开始时指向指针数组num的首元素num[0],而num[0]是一个指针型的元素,它指向整型数组a的首元素a[0]。开始时p的值是&num[0],* p是num[0]的值即&a[0],*( * p)是a[0]的值。因此第1个输出的是a[0]的值1。然后执行p++,p就指向num[1],再输出**p,就是a[2]的值3了。