直接上例子:
-
一维数组data[5] = {10,20,30,40,50} 数组名data 数组指针 int (*p)[5]=&data 将数组指针p强转为二级指针int **p1 将数组指针p强转为int *p2 对应含义: 表示数组首元素的地址 1.数组指针表示整个数组的首地址(数组首元素地址的地址) 2.数组名和数组指针数值上是相等的,因为指向同一个位置 3.但+1时是不同的,data+1跨过一个元素,p+1跨过整个数组 4.数组指针对应二维数组 p1数值上为首地址;*p1数值上为0xa(等于第一个元素的值,但却用十六进制表示,表明虽然*p1是一个指针,但却为其赋予元素的值) p2数值上为首地址;*p2数值上为10(等于第一个元素的值) -
二维数组data[2][5] = {{1,2,3,4,5},{6,7,8,9,10}} 数组名data 数组指针 int (*p)[2][5] 将data强转为二级指针int **p1 将data强转为int *p2 对应含义: 表示数组首元素(即首行)的地址 与三维数组相对应 p1数值上为首地址;*p1数值上为0x1(等于第一个元素的值,但却用十六进制表示,表明虽然*p1是一个指针,但却为其赋予元素的值) p2数值上为首地址;*p2数值上为1(等于第一个元素的值) -
总结:
-
n维数组与n-1维的数组指针 等价
-
二维数组和一维数组指针在形式上类似于二级指针。下面以一维数组指针进行阐述,由于首元素地址(数组名)与数组指针(首元素地址的地址)在数值上相同,因而这种二级指针更像是一级指针。但在形式上又不能直接只采用一级指针,因为这样无法处理跨行(跨越整个数组)的问题,而采用二级指针的形式则可以进一步抽象出行(一维数组),进而加1时能跨越整个行。另一方面,这实际上也和多维数组存储时是连续存储的有关,因为连续存储,所以只需要一个指针加偏移量就可以访问所有元素,因而实际上可以不抽象出一个类似二级指针的形式。但为了方便数组的多维化展示,最终搞出了这种形式。(个人理解)
-