字节顺序大小端模式

29次阅读

共计 1093 个字符,预计需要花费 3 分钟才能阅读完成。

假如变量 x 类型为 int,位于地址 0x100 处,有一个十六进制值为 0x01234567,地址范围为0x100~0x103 的字节顺序依赖于机器的类型。

大端模式Big-endian

大端模式,是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放;这和我们的阅读习惯一致。

/*
 *
    |---------------------------------------|
    |Big-endian                             |
    |---------------------------------------|
    |  buf   | 0x100 | 0x101 | 0x102 | 0x103|
    |---------------------------------------|
    |  ...   |   01  |   23  |  45   |  76  |
    |---------------------------------------|
*
*/

小端模式Little-endian

小端模式,是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中,这种存储模式将地址的高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低。

 /*
 *
    |---------------------------------------|
    |Little-endian                          |
    |---------------------------------------|
    |  buf   | 0x100 | 0x101 | 0x102 | 0x103|
    |---------------------------------------|
    |  ...   |   67  |   45  |  23   |  01  |
    |---------------------------------------|
*
*/
#include <stdio.h>

typedef unsigned char *byte_pointer;

//void show_bytes(byte_pointer start, int len);

void show_bytes(byte_pointer start, int len)
{
     int i;
     for (i = 0; i < len; i++)
     {printf( "%.2x",start[i]);
        printf("\n");
     }
}
int main()
{
   int val = 0x12345678;

   byte_pointer valp = (byte_pointer)&val;
 
   show_bytes(valp,1); // 78
   show_bytes(valp,2); // 78 56 
   show_bytes(valp,3); // 78 56  34

   return 1;
}

正文完
 0