什么是指针?
指针是一个变量,其值为另一个变量的地址,即,内存位置的直接地址。就像其他变量或常量一样,您必须在使用指针存储其他变量地址之前,对其进行声明。
要理解指针就要先理解计算机的内存。计算机内存会被划分为按顺序编号的内存单元,内存的名称就是变量名。由于内存中的每一个字节都有一个唯一的编号,因此,在程序中使用的变量,常量,甚至数组、函数等数据,当他们被载入到内存中后,都有自己唯一的一个编号,这个编号就是这个数据的地址。指针就是这样形成的。
类型说明
类型 | 说明 |
---|---|
int p; | 声明一个普通的整型变量 |
int * p; | 首先从p 处开始,先与*结合,所以说明p是一个指针,然后再与int 结合,说明指针所指向的内容的类型为int 型.所以P是一个返回整型数据的指针 |
const int * p; | 指向的变量值不能修改,但地址可以修改 |
int const *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,char); | 从p处开始,先与指针结合,说明p是一个指针,然后与()结合,说明指针指向的是一个函数,然后再与()里的int 结合,说明函数有一个int 型和char型的参数,再与最外层的int 结合,说明函数的返回类型是整型,所以p是一个指向有一个整型参数且返回类型为整型的函数的指针 |
int *(*p(int))[3]; | 可以先跳过,不看这个类型,过于复杂从p 开始,先与()结合,说明p是一个函数,然后进入()里面,与int 结合,说明函数有一个整型变量参数,然后再与外面的 * 结合,说明函数返回的是一个指针,然后到最外面一层,先与[]结合,说明返回的指针指向的是一个数组,然后再与 * 结合,说明数组里的元素是指针,然后再与int 结合,说明指针指向的内容是整型数据.所以p是一个参数为一个整数据且返回一个指向由整型指针变量组成的数组的指针变量的函数. |