小端系统地址访问

  1. 有这么一道笔试题:
  2. struct data  
  3. {  
  4.     int a;  
  5.     short s;  
  6. };  
  7. int main()  
  8. {  
  9.     struct data d;  
  10.     d.s=0x0102;  
  11.     char *p=&d  
  12.     printf("%d"(int)(*(p+4)));  
  13. }  
栈是由高地址向低地址增长,加入cout<<&d<<endl<<&d.a<<endl<<&d.s<<endl测试,
输出结果:0x001FF808
                     0x001FF808
                    0x001FF80C
说明结构体内,定义顺序从上到下对应地址从低到高,      a是从0x001FF808开始存储,s是从0x001FF80C开始存储,但是要注意:a和s都是低位存到低地址,高位存到高地址,
p+4时移动到0x001FF80C,也就是s的低位,应该是2,而不是0

附:

int endian( void )
{
     union
     {
         int i;
          char a;
      }e;
     e.i=1;
     return e.a==1;

}

如果系统是小端则返回1,大端返回0;


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值