数组内存的首地址和数组第0个元素的地址什么区别?
它们的地址值是相等的;
第0个元素的地址如果是p,则p+1就是第1个元素的地址;
数组的首地址如果是p,则p+1就跳过这个数数组而指向这个数组最后一个元素最后一个字节的下一字节。
#include <stdio.h>
#include <malloc.h>
#include <string.h>
main()
{
int j=0, k,k1,* k3,i;
int ch[][4]={{1,2,3,4},{5,6,7,8}};
int (*p1)[4];//数组指针
int *p2[2]={ch[0],ch[1]};//指针数组
k1=sizeof(ch)/sizeof(int);
//1、按照一维数组的形式输出
for(i=0;i<k1;i++)
{
printf("i=%d,ch=%d\n",i,*(&ch[0][0]+i));
}
//2、按照二维数组的形式输出
for(i=0;i<2;i++)
for(j=0;j<4;j++)
{
printf("ch=%d\n",ch[i][j]);
}
//3、按照数组指针的形式输出
p1=ch;
for(i=0;i<k1;i++)
{
printf("i=%d,ch=%d\n",i,*((*p1)+i));
}
for(i=0;i<2;i++)
for(j=0;j<4;j++)
{
printf("i=%d,ch=%d\n",i,*((*(p1+i)+j)));
}
//4、按照指针数组的形式输出
for(i=0;i<2;i++)
for(j=0;j<4;j++)
{
printf("i=%d,ch=%d\n",i,p2[i][j]);
}
return 1;
}