大家都知道一维数组名即是一个指针常量,它代表数组第一个元素的地址,我们知道一维数组的长度,那么可以通过数组名输出一维数组的所有元素:#include int main(void) { int i;int a[5] = {1, 2, 3, 4, 5};int *p = a;for( i = 0; i < 5; i++ ) printf( “%d/n”, *(p + i) );return 0;} 但是在多维数组中,数组名却是第一个数组的地址,怎么理解呢?比如说定义一个二维数组:int a[2][5] = {1, 2, 3, 4, 5,6, 7, 8, 9, 10};那么数组名a就是二维数组的第一行一维数组的地址,而不要错误的认为它代表的是第一行第一个元素的地址噢,那我们应该怎么正确的申明一个指向整形数组的指针呢? int (*p)[5] = a;它使 p 指向二维数组的第一行的一维数组(注意是指向的第一行一维数组)。 #include int main(void) { int i;int a[2][5] = {1, 2, 3, 4, 5,6, 7, 8, 9, 10};int (*p)[5] = a;for( i = 0; i < 5; i++ ) printf( “%d/n”, *(*p + i) );return 0;}上面的程序也是依次输出了1~5,这里 p 是指向二维数组的第一行地址的指针,那么 *p 即是代表第一行数组,那么也就是第一行数组的地址,我们可以再通过 *(*p + i) 输出第一行数组的各个元素。有点乱?呵呵,再仔细想想,或者直接说 a 是指向的第一行,那么 *a 就代表第一行的那个一维数组,但 *a 仍然是一个指针常量,而 **a 才是这个一维数组的第一个元素的值。 如果我们要定义一个指针可以逐个访问元素呢?下面两种方法都是正确的声明和赋值:int *p = &a[0][0];int *p = a[0];第一种方法,就干脆把数组的第一行第一个元素取地址给指针变量p,这可能是最直观的方法。 第二种方法,其实原理一样,前面刚说了 a 是指向的第一行,第一行是一个一维数组,那么a[0]就是这个一维数组的第一个元素的地址。特别注意这里的 a[0] 不是一个值,而是一个地址。附字符二维数组的区别。 #include int main(void) { int i;int a[2][5] = {1, 2, 3, 4, 5,6, 7, 8, 9, 10};int *p = a[0];for( i = 0; i < 10; i++ ) printf( “%d/n”, *(p + i) );return 0;}上面的代码就输出了二维数组中的所有元素。 附:这里的a[0]却输出了hello int main(void) { char a[2][10] = {“hello”, “hi”};printf( “%s/n”, a[0] );return 0;}
① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;
② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。