C语言,指针,书中举例的数组在赋给指针时加了地址符…
intarray[10];int(*pa)[10];pa=&array;pa是一个指针,指向含有10个元素的整形数组,可用整个数组的首地址来初始化它,在语句pa=&arr...
int array[10];
int (*pa)[10];
pa =&array;
pa是一个指针,指向含有10个元素的整形数组,可用整个数组的首地址来初始化它,在语句pa=&array中,array代表数组本身。
这里的array为什么可以加&… 展开
int (*pa)[10];
pa =&array;
pa是一个指针,指向含有10个元素的整形数组,可用整个数组的首地址来初始化它,在语句pa=&array中,array代表数组本身。
这里的array为什么可以加&… 展开
4个回答
展开全部
array和&array,地址相同,但含义和类型不同,array代表数组array首元的地址,类型是int*;&array代表数组array本身的地址,类型是int(*)[10]。因此,要赋值给数组指针pa,应该使用类型相同的&array而不是array。
追问
那如果int (*pa)[10]变成int*pa的话是不是赋值语句就改为pa=array?如果是的话那这两个pa有什么区别呢?
追答
两个pa的区别在于它们的步进不同,int *pa的步进是一个int类型,即pa+1代表向后移动一个int长度;int(*pa)[10]的步进是一个int[10]类型,即pa+1代表向后移动一个int[10]的长度。int(*pa)[10]这种写法多用于二维数组指针。例如有二维数组a[10][10],则int(*pa)[10]=a指向数组a的第一行,pa+1代表第二行;而int *pb=a[0]指向数组a第一行第一个元素,pb+1代表第一行第二个元素。
展开全部
显式调用和隐式调用的区别,都是int (*)[10]类型。(类型描述不准确,修改一下)
没有&的时候编译器默认也是取数组首地址(不是首元素地址,虽然地址值一样但是类型不同。如果是 &array[0][0] ,则类型是 int * ,即首元素地址,为普通指针类型)。
没有&的时候编译器默认也是取数组首地址(不是首元素地址,虽然地址值一样但是类型不同。如果是 &array[0][0] ,则类型是 int * ,即首元素地址,为普通指针类型)。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
约定把,array = &array;
也就是说数组名就代表了数组首个元素的地址
也就是说数组名就代表了数组首个元素的地址
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询