C语言一维数组指针

#include<stdio.h>void main(){ int *p,*q,a[5],b[5],i; p=&a[0]; q=&b[0]; printf("please input array a:\n"); for(i=0;i<5;i++) scanf("%d",p++); /*为数组a中的元素赋初值*/ printf("please input array b:\n"); for(i=0;i<5;i++) scanf("%d",q++); /*为数组b中的元素赋初值*/ p=a; printf("array a is:\n"); for(i=0;i<5;i++) printf("%d",*(p+i)); /*输出数组a中的元素*/ printf("\n"); printf("array b is:\n"); for(i=0;i<5;i++) printf("%d",*(q+i)); /*输出数组b中的元素*/ printf("\n");}这段代码,中的p=a;是什么意思?为什么去掉之后就会直接输出a[5]的地址?但q=b;却可有可无,就算不存在p=b,也能正确输出b[5]的,数据?

第1个回答  2018-08-03

    p=&a;才是=号两边类型匹配。因为p被声明为指向有4个元素的一维整型数组的指针,而a被定义为一个整型数组的第一个元素的指针,所以写成p=a;等号两边类型不匹配,连编译都过不了。而&a就是一个有4个整型元素的一维数组的指针——就是说在int a[4]={1,3,5,7};的定义后,a是1的地址,a+1就2的地址;而&a的值虽与a相同,但&a是整个数组{1,3,5,7}的地址,&a+1就指向7后面的那个单元了。而int (*p)[4];这种声明恰好就是&a的意思,即p是个指针,指向一个4元素整型数组,也就是p+1就要跳过4个int元素所占有的空间。

    printf("%d\n",(*p)[3]);中的(*p)[3]的意思是这样的:有了p=&a;后,p的地址“值”就是1的地址“值”,但意思是紧挨着存放的1,3,5,7这4个int数的首地址,*p后就是第一个元素1的地址了,那么(*p)[3]就向后移动3个元素位置,应该是7了……这里把*p用()括起来是因为[]的优先级比*高,不括起来就被解释成*(p[3])了,意思就大错了!

    这里涉及的指针操作表述起来有些“绕”,得慢慢体会……

追问

我不是问运行过程,我是问在输入完成后,为什么必须要有p=a;这条语句,为什么q=b,可有可无,

相似回答