首先说一个无关的小问题:①数组a[ ]的用法竟与指针*p的用法类似(可以有*(a+i)等,它就表示a[i]),即数组与指针类型,就像char b[ ] 与 string b类似。
②数组作形参时,声明为void max(int a[ ]),那么在输入形参时,时只输入数组名即可,如max(a),而不是max(a[ ]),也不是max(a[3])等。
正题:在主函数中声明了一个int a[3],a表示a[0]的地址,但a是不可以a++或++a的,即不可以用++a来表示a[1]的地址,也就是说,a是一个const常量;
而在普通函数中,如果声明了一个数组形参,如void m(int a[]),那么这个a,在函数m中,是可以a++或++a的,且++a就表示a[1]的地址。
另:对二维数组如 int a[3][3]={{1,2,3},{4,5,6},{7,8,9}} 来说,a表示什么?要这么去想:
a表示a[3][3]的首元素的地址。
那么a[3][3]的首元素是什么?是a[0],还是a[0][1]?
先看a[3][3]是什么:a[3][3]={{1,2,3},{4,5,6},{7,8,9}},那么它的首元素是{1,2,3},而不是1。
{1,2,3}是什么?是a[0]。即,a[0]是一个数组名,如a[0][0]=1,其中数组名是a[0],元素编号是[0]。
那么再回到最初的问题看,a是什么?a是a[3][3]的首元素的地址,即a[0]的地址,而不是a[0][1]的地址。
也就是说,a=&a[0]。
那么,也就有 *a=a[0],即,*a是一个数组{1,2,3},而不是第一个元素1。
又因为前面说了,a[0]表示一个数组{1,2,3},即a[0]是一个数组名,那么a[0]就表示其中第一个元素的地址,也就是a[0][1]的地址,即&a[0][1]。
那么,就有a=&a[0]=&(&a[0][1])。
同样也有,*(a[i]+j)或*(*(a+i)+j)都表示a[i][j]。