C测试-普通变量和数组的内存分配顺序

  • 如下所示的一段代码,依次定义了 i,j,a[5],k 这几个整型数据,再依次打印出 i,j ,数组 a ,k 各个元素的地址。
#include"stdio.h"
int main()
{
     int i;
     int j;
     int a[5];
     int k=3;
     printf("整型变量i的地址:%d\n整型变量j的地址:%d\n",&i,&j);/*输出 i,j 的地址*/
     printf("数组首元素地址:%d\n",a);/*输出数组的首地址*/
     for(i=0;i<5;i++)
        printf("数组元素a[%d]的地址:%d\n",i,&a[i]);/*输出数组元素的地址*/
     printf("整型变量k的地址:%d\n",&k);/*输出 k 的地址*/
	 return 0;
}
  • 运行结果如下图所示:
    在这里插入图片描述
  • 可以看出, 系统根据定义顺序依次对 i,j,a[5],k分配的内存是从高地址到低地址,而数组内部元素的内存分配都是从低地址到高地址
  • 两个依次定义的数据地址间的大小具体由编译器自行决定 ,例如上例使用的DEVC++为每一个整形数据分配4个字节(32位)。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MR_Promethus

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值