谭浩强老师的《C语言程序设计》第四版第八章,关于指针与二维数组的关系。
始终记住,数组名是首元素的地址。
二维数组是一维数组的数组,所以可以看成是三个一维数组的集合。例如a[3][3],可以看成是a[0][0],a[0][1],a[0][2]和a[1][0],a[1][1],a[1][2]和a[2][0],a[2][1],a[2][2]三个一维数组的数组。a就是第一个一维数组的地址,a+1就是第二个一维数组的地址,a+2就是第三个一维数组的地址。
那么,二维数组的数组名可以看作是{a[0][0],a[0][1],a[0][2]}的地址。那么再从一维数组看,a[0]又是{a[0][0],a[0][1],a[0][2]}的地址。所以a和a[0],a+1和a[1]都是等价的。
所以二维数组就是地址的地址,这就是为什么*a明明解除了一层指针引用但还是表示地址的原因。
所以a+1和*(a+1)是等价的。*(a+1)把范围缩小到一维数组,*(a+1)+0表示的就是a[1][0]的地址,*(a+1)+1表示的就是a[1][1]的地址
要想表示数组具体的值,就要解除两层引用,*(*(a+i)+j).
或者解除一层引用,*(a[i]+j).
或者直接a[i][j].
要得到具体的值,就要把指针范围缩小到一维数组再解除引用。
总而言之,记住两句话。
1,数组名表示首元素的地址。关于这个有点想递归思想,一维数组的数组名是第一个元素的地址,二维数组名是第一个一维数组的地址。以此类推。
2,二维数组是一维数组的数组,同理可以延伸到多维数组。