大小端模式

/*
 * 2020/3/16    14:37    yin
 *
 *    大高低, 小高高
 */

/*
 * 大小端模式字节序
 */
      MSB    LSB    
    0x12345678
                        0        1        2        3    byte

        little endian    78        56        34        12            // 高位存高地址,低位存低地址

        big    endian    12        34        56        78            // 高位存低地址,低位存高地址


                        3        2        1        0    byte

        big endian        78        56        34        12            

        little endian    12        34        56        78            


        // 使用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)

        // 为什么会有大小端模式之分呢

        因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为 8bit。
        对于位数大于 8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。
        因此就导致了大端存储模式和小端存储模式。


    大端模式

        所谓的大端模式(Big-endian),是指数据的高字节,保存在内存的低地址中,而数据的低字节,保存在内存的高地址中,
        这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放;

        例子:

            0000430: e684 6c4e 0100 1800 53ef 0100 0100 0000
            0000440: b484 6c4e 004e ed00 0000 0000 0100 0000
            在大端模式下,前32位应该这样读: e6 84 6c 4e ( 假设int占4个字节)

        记忆方法: 地址的增长顺序与值的增长顺序相反

    小端模式

        所谓的小端模式(Little-endian),是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中,这种存储模式将地址的
        高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低,和我们的逻辑方法一致。

        例子:

            0000430: e684 6c4e 0100 1800 53ef 0100 0100 0000
            0000440: b484 6c4e 004e ed00 0000 0000 0100 0000
            在小端模式下,前32位应该这样读: 4e 6c 84 e6( 假设int占4个字节)

        记忆方法: 地址的增长顺序与值的增长顺序相同


/*
 *
 *       | +0 | +1 | +2 | +3 |
 *   ----+----+----+----+----+
 *    LE | 78 | 56 | 34 | 12 | 0x12345678
 *   ----+----+----+----+----+
 *       | wr |      rd      |
 *       +----+----+----+----+
 *
 *   ----+----+----+----+----+
 *    BE | 12 | 34 | 56 | 78 | 0x12345678
 *   ----+----+----+----+----+
 *       |      rd      | wr |
 *       +----+----+----+----+
 */


 有两种判断方法:

A:

bool IsBig_Endian()
{
    unsigned short test = 0x0102;
    if( *( (unsigned char*) &test ) == 0x01 )
         return TRUE;
    else
         return FALSE;

}

B:

int isBigEndian(){
   union{
        short a;
        char b;
   }c;

   c.a=1;
   return (c.b==1);

}

/* 小端之间的转换 */

1、小端转换为大端

#include <stdio.h>

void show_byte(char *addr, int len)
{
    int i;

    for (i = 0; i < len; i++)
    {
      printf("%.2x \t", addr[i]);
    }

    printf("\n");
}

int endian_convert(int t)
{

    int result;
    int i;

    result = 0;
    for (i = 0; i < sizeof(t); i++)
    {
      result <<= 8;
      result |= (t & 0xFF);
      t >>= 8;
    }

    return result;
}

int main(void)
{
    int i;
    int ret;

    i = 0x1234567;

    show_byte((char *)&i, sizeof(int));
    ret = endian_convert(i);
    show_byte((char *)&ret, sizeof(int));

    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值