多级指针
这里只介绍二级指针
所有的指针都是用来保存地址的,只不过因为保存地址的数据类型不同,从而产生多种指针类型。
前面说到,一级指针是用来保存普通变量的地址,那一级指针的地址又用什么来保存的?自然是使用更高级的指针,也就是二级指针。高级指针也就是一个套娃的过程。
规则: * + 地址 ->访问地址中的内容
int data;
int *p = &data;
int **q = &p;
int ***t = &q;
p = &a; // *p = *(&a) *p< == > a
q = &p; // q =(&p) == > *q = p; **q < == >*p < == > a
在32bit系统中,所有指针变量都是4bytes(64bit是8bytes),多级指针每次移动都是4bytes。因为一个指针大小是4bytes。
不同类型的指针,在移动的时候,每次移动的大小也是它保存对象的大小。
指针数组
本质是一个数组,只不过该数组由多个指针来构成,所以我们叫指针数组。
每个指针中存放的都是地址值,定义一个指针数组等价于定义了多个指针变量。
//数据类型 * 指针变量名[元素个数]
char a = 10, b = 20, c = 30;
char *array[] = {&a,&b,&c,NULL};
array[0] = &a;
*array[0] = *(&a) = a = 10;
array < == > &array[0] < == > &(&a)
**array < == > a
那么指针数组的首地址应该用什么指针变量来保存呢?保存指针地址自然是更高级的指针,所以应当定义二级指针来保存。
array < == > &array[0]
array[0]的类型是char *
&array[0]应该定义 char ** 的类型来保存
char **q = array;// q< == > array
数组指针
前面所学的一级指针都指向一个变量,要是指向多个变量组成的数组,我们就叫它数组指针。本质上是一个指针,只不过该指针指向一个数组。
// 数据类型 (*指针变量名)[元素个数]
int (*p) [5]
数组指针用于二维数组的行指针,何为行指针?
指针和二维数组
int a[3][2];
a[0],a[1],a[2]就是这个二维数组的行指针
a < == > &a[0]
a + 1 < = = > &a[0] + 1 < == >a[1] (一次偏移两个元素大小,也就是一行)
a[0] < == > &a[0][0]
a[0] + 1 < == > &a[0][0] + 1 < == > &a[0][1](一次移动一个元素大小,移动一列)
(这里的移动一列是对于上图而言的,实际上就是移动一个元素大小)
总结:
行指针:a,a + 1,a + 2我们叫做行常量指针,简称行指针,每次移动一行元素大小
列指针:a[0],a[1],a[2]我们叫做列常量指针,简称列指针,每次移动一列的大小,即一个元素的大小
行指针 + * —>列指针
列指针 + & —>行指针
列指针 + * —>获得数据