你再也不惧怕指针 小程序
前言:复杂类型说明 数组
要了解指针,多多少少会出现一些比较复杂的类型,因此我先介绍一下如何彻底理解一个复杂类型,要理解复杂类型其实很简单,一个类型里会出现不少运算符,他们也像普通的表达式同样,有优先级,其优先级和运算优先级样,因此我总结了一下其原则:从变量名处起,根据运算符优先级结合,一步一步分析. 函数
下面让咱们先从简单的类型开始慢慢分析吧: spa
int p; //这是一个普通的整型变量 指针
int *p; //首先从P 处开始,先与*结合,因此说明P 是一 变量
//个指针,而后再与int 结合,说明指针所指向的内容的类型为int 型.因此P 是一个返回整型数据的指针 程序
int p[3]; //首先从P 处开始,先与[]结合,说明P 是一个数组,而后与int 结合,说明数组里的元素是整
//型的,因此P 是一个由整型数据组成的数组 总结
int *p[3]; //首先从P 处开始,先与[]结合,由于其优先级
//比*高,因此P 是一个数组,而后再与*结合,说明数组里的元素是指针类型,而后再与int 结合,
//说明指针所指向的内容的类型是整型的,因此P 是一个由返回整型数据的指针所组成的数组 数据
int (*p)[3]; //首先从P 处开始,先与*结合,说明P 是一个指针而后再与[]结合(与"()"这步能够忽略,只是为
//了改变优先级),说明指针所指向的内容是一个
//数组,而后再与int 结合,说明数组里的元素是
//整型的.因此P 是一个指向由整型数据组成的数
//组的指针 运算符
int **p; //首先从P 开始,先与*结合,说是P 是一个指针,然
//后再与*结合,说明指针所指向的元素是指针,然
//后再与int 结合,说明该指针所指向的元素是整
//型数据.因为二级指针以及更高级的指针极少用
//在复杂的类型中,因此后面更复杂的类型咱们就
//不考虑多级指针了,最多只考虑一级指针.
int p(int); //从P 处起,先与()结合,说明P 是一个函数,而后进入
//()里分析,说明该函数有一个整型变量的参数
//而后再与外面的int 结合,说明函数的返回值是
//一个整型数据
Int (*p)(int); //从P 处开始,先与指针结合,说明P 是一个指针,而后与
//()结合,说明指针指向的是一个函数,而后再与()里的
//int 结合,说明函数有一个int 型的参数,再与最外层的
//int 结合,说明函数的返回类型是整型,因此P 是一个指
//向有一个整型参数且返回类型为整型的函数的指针
int *(*p(int))[3]; //能够先跳过,不看这个类型,过于复杂 //从P 开始,先与()结合,说明P 是一个函数,而后进 //入()里面,与int 结合,说明函数有一个整型变量 //参数,而后再与外面的*结合,说明函数返回的是 //一个指针,,而后到最外面一层,先与[]结合,说明 //返回的指针指向的是一个数组,而后再与*结合,说 //明数组里的元素是指针,而后再与int 结合,说明指 //针指向的内容是整型数据.因此P 是一个参数为一个 //整数据且返回一个指向由整型指针变量组成的数组 //的指针变量的函数.
说到这里也就差很少了,咱们的任务也就这么多,理解了这几个类型,其它 的类型对咱们来讲也是小菜了,不过咱们通常不会用太复杂的类型,那样会 大大减少程序的可读性,请慎用,这上面的几种类型已经足够咱们用了.