如下所示:
1,int *p
2,int **p
3,int *p[10]
4,int (*p)[10]
5,int *p(int)
6,int (*p)(int)
7,int (*p[10])(int)
这其中指针的含义:
1,一个指向整形数据的指针
2,一个指向整形数据指针的指针
3,一个包含有10个元素的数组,每个数组元素为一个指向整形数据的指针
4,一个指向一个含有10个元素数组的指针,也可以理解为数组的首地址可以用p来指向
5,一个简单的函数,有一个整形参数,并且返回值为一个指向整形数据的指针
6,一个函数指针,该函数有一个参数,类型为整形数据,返回一个整形数据
7,可以理解为一个有10个元素的数组,每个元素都为一个函数指针,这个函数都有一个整形参数,且返回一个整型数据
当然这其中的类型可以任意。下面对其中的两个进行简单测试:
由于第1,2,3,5,6比较好理解,就不测试,主要测试4,7。
namespace four {//第四个
void fun() {
//为了说明问题,数据量减小到5
int(*p)[5] = NULL;
int num[5] = { 10,20,30,40,50 };
//如果 语句 p = #不报错,则解释正确
p = #
//访问方式有:1,p[0][i] 2,*(p[0]+i) ;i range from zero to four
cout << *(p[0] + 1) << endl;
}
}
namespace seven {//第七个,这其中函数参数,返回值类型都可变
int f1(int x) {
return x;
}
int f2(int x) {
return x;
}
int f3(int x) {
return x;
}
void test() {
int(*p[3])(int);
//这样可以实现类似跳转表一些非常便捷的操作,下面可以根据规律批量赋值
p[0] = f1;
p[1] = f2;
p[2] = f3;
cout << p[1](3)<<endl;//调用f2函数
}
}
简单测试:
int main() {
four::fun();
seven::test();
return 0;
}