大小端

MSB: Most  Significant Bit ------- 最高有效位
LSB: Least Significant Bit ------- 最低有效位


网络字节序是big-endian, 因为网络很大
Intel x86           全部         Little endian   <-----x86系统是小端字节序系统
MIPS                NT           Little endian
MIPS                UNIX         Big endian
IXP1200 ARM核心     全部         Little endian
Motorola680x        全部         Big endian


big-endian:   MSB存放在最低端的地址上
little-endian:LSB存放在最低端的地址上
举例,双字节数0x1234以little-endian的方式存在起始地址0x00002000中:
| data |<-- address
| 0x34 |<-- 0x00002000
| 0x12 |<-- 0x00002001


采用大端方式进行数据存放符合人类的正常思维,而采用小端方式进行数据存放利于计算机处理。
如果将一个32位的整数0x12345678存放到一个整型变量(int)中,这个整型变量采用大端或者小端模式在内存中的存储由下表所示。
为简单起见,本书使用OP0表示一个32位数据的最高字节MSB(Most Significant Byte),使用OP3表示一个32位数据最低字节LSB(Least Significant Byte)。
---------------------------
地址偏移 大端模式 小端模式
0x00     12(OP0) 78(OP3)
0x01     34(OP1) 56(OP2)
0x02     56(OP2) 34(OP1)
0x03     78(OP3) 12(OP0)
---------------------------
如果将一个16位的整数0x1234存放到一个短整型变量(short)中。这个短整型变量在内存中的存储在大小端模式由下表所示。
---------------------------------
地址偏移 大端模式 小端模式
0x00     12(OP0) 34(OP1)
0x01     34(OP1) 12(OP0)
-------------------------------------


        // 联合体uniON的存放顺序是所有成员都从低地址开始存放
        union
        {
        unsigned int a;
        unsigned char b;
        }c;
        c.a = 1;
        printf("%d  %d  %d\n", &c, &c.a, &c.b);
        if(c.b == 1) {
            printf("small \n");
        } else {
            printf("big \n");
        }


        int aa = 1;
        char *p = (char*)&aa;
        printf("%d %d\n", p, p+1);
        if(*p == 1) {
            printf("small \n");
        } else {
            printf("big \n");
        }
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值