#include<stdio.h>
#include<stdlib.h>
int main()
{
int a[5]={1,2,3,4,5};
//以十六进制打印数组的首地址 这里a与&a,&a[0]一样的结果
printf("%x\n",a);
printf("%x\n",&a);
printf("%x\n",&a[0]);
//以十进制打印数组的首地址
printf("%d\n",a);
//输出第一个数组元素的值
printf("%d\n",a[0]);
//数组在内存是连续排列
printf("%d\n",sizeof(a));//5*4=20字节 ,//是20个不是21,\0只有对字符串才生效
//求数组多少个元素,这个是最标准的求法
printf("%d\n",sizeof(a)/sizeof(int));//5个元素
//数组的本质:一片连续的内存空间
for(int i=0;i<5;i++)
{
printf("a[%d]=%d,&a[%d]=%x\n",i,a[i],i,&a[i]);
}
//对一个大小为N,类型为int的数组,其占据的内存大小为:
//N*sizeof(int)-->N*4
//如果说第一个元素在内存中的地址为p,那么第M个元素(M不大于N)在内存中的地址可表示为:
//p+(M-1)*sizeof(int)//从0开始所以要减1
//一个进程不能读写另外一个进程
return 0;
}
int main1()
{
int a[10];//数组越界不报错
//因为数组外部的内存空间,不确定是否有权限,
//如果越界访问,程序会崩溃
for(int i=0;i<16;i++)//把16改大些呢 1600000
{
a[i]=i+1;
}
}
C语言--数组首地址问题小记
最新推荐文章于 2023-09-07 21:59:21 发布