指针数组:
定义:int *p[n]
[]优先级高先与p结合成数组, 再由int *说明这是一个指针数组,它有n个指针类型的数组元素
“[]”的优先级比“*”要高。p1 先与“[]”结合,构成一个数组的定义,数组名为p1,int *修饰的是数组的内容,即数组的每个元素。那现在我们清楚,这是一个数组,其包含5个指向int 类型数据的指针,即指针数组。
数组指针:
定义:int (*p)[n]
()优先极高首先说明它是一个指针,指向一个整形的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。
在这里“()”的优先级比“[]”高,“*”号和p2 构成一个指针的定义,指针变量名为p2,int 修饰的是数组的内容,即数组的每个元素。数组在这里并没有名字,是个匿名数组。那现在我们清楚p2 是一个指针,它指向一个包含10 个int 类型数据的数组,即数组指针
指针数组和数组指针的内存布局
指针数组:首先它是一个数组,数组的元素都是指针,数组占多少字节由数组本身的大小决定,每一个元素都是指针,在32位系统下任何类型的指针都占4个字节,它是“储存指针的数组”的简称。
数组指针: 首先它是一个指针,它指向一个数组。在32位系统下任何类型的指针都占四个字节,至于它指向的数组占多少字节要看数组的大小,它是“存储数组的指针”的简称