首先我们先来了解一下指针和数组的基本概念。
1.指针是一个地址,int *p=&a,p为指针变量,里面存放了a的地址,因此,将地址形象化的称为指针。
2.数组是指一组类型相同元素的集合。
3.指针数组: 一个存放指针的数组,其元素均为指针类型数据,也就是说数组中的每个元素都存放地址,相当于一个指针变量。 定义一个指针数组 int *a[5],分析如下:由于[]的优先级比*的高,所以p首先跟[]结合,形成数组形式,p数组中有四个元素,p在与*结合,表示出该数组是指针类型,每个指针变量都可以指向一个整形变量。
4.数组指针:指向某一个数组的指针,本质上还是指针。int (*p)[6] ,首先p与*结合,说明p是个指针,指向一个大小为6的整形数组,叫数组指针。
5.函数指针:本质是一个指针,指向一个函数,例如:int (*func[])();
6.函数指针数组指针:本质上是一个指针,指向一个元素都为函数指针的数组。例如:int (*(*func)[])();
7.函数指针数组:例如:int (*arr[6])();首先arr与[]结合,说明arr是数组,数组的内容是int (*)()类型的函数指针。把函数的地址存放到一个数组中。
程序举例:
//指针数组
#include<stdio.h>
#include<windows.h>
int main()
{
char *arr[2]={"hello","world"};//指针数组
printf("%s %s\n",arr[0],arr[1]);
system("pause");
return 0;
}
//数组指针
#include<stdio.h>
#include<Windows.h>
int main()
{
int arr[5][2]={{1,2},{3,4},{5,6},{7,8},{9,10}};
int (*p)[2]=arr;//数组指针
int i=0;
int j=0;
for(;i<5; i++)
{
for(; j<2; j++)
{
printf("%d, %d ,%d\n",p[i][j],*(p[i]+j),arr[i][j]);
}
}
system("pause");
return 0;
//函数指针
#include<stdio.h>
#include<Windows.h>
int Add(int x,int y)
{
return x+y;
}
int main()
{
int a=1;
int b=2;
int ret=(*Add)(a,b);//函数指针
printf("%d\n",ret);
system("pause");
return 0;
}
//函数指针数组,实现转移表
#include<stdio.h>
#include<Windows.h>
int Add(int x,int y)
{
return x+y;
}
int main()
{
int x;
int y;
int ret=0;
int (*p[1])(int x, int y)={Add};
scanf("%d%d",&x,&y);
ret=(*p[0])(x,y);
printf("add=%d\n",ret);
system("pause");
return 0;
}
//指向函数指针数组的指针void *((*p)[5])()
#include<stdio.h>
#include<windows.h>
char *fun(char *str)
{
printf("%s\n",str);
return str;
}
int main()
{
char *(*a[1])(char * p);
char *(*(*p)[1])(char *p);
p=&a;
a[0]=fun;
p[0][0]("hello world");
system("pause");
return 0;
}