【数据存储概念】大端存储&&小端存储

这里写目录标题

  • 大小端介绍
  • 大端小端存储的特征
  • 如何判断大小端

大小端介绍

本文采用整形来举列子说明大端存储和小端存储的区别及原理

特别注意:大小端模式是指字节序的大小端模式,当一个数据的所占的内存大于一个字节时,就会按照大端或小端顺序存储。

之前学过对于整形来说:数据存放内存中其实存放的是补码。

如 int temp = 0x1122 在内存中存储内容如下
【数据存储概念】大端存储&&小端存储_第1张图片

我们可以看到对于temp存储的是补码,但是我们发现顺序是数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。

大端小端存储的特征

大端(存储)模式:是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中;

小端(存储)模式:是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。
【数据存储概念】大端存储&&小端存储_第2张图片
由上图结合上面介绍所用VS调试窗口内容可知,VS用的存储方式为小端存储,以及我们常用的X86结构也是采用小端存储。

采用大端存储比较常见的为51单片机

如何判断大小端

由于小端存储数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。

利用这个特性可定义 int i = 1;
1:如果是小端存储,由于1的值没超过一个字节的表示范围,所以数值1必定存在于最低的字节中。
2:如果是大端存储,所以数值1必定存在于最高的字节中。
3:根据前两点,只要我们取最低字节并判断是否为1即可
【数据存储概念】大端存储&&小端存储_第3张图片

int main()
{
    int i = 1;
    char cur = (char)i;
    if (cur == 1)
        printf("我是小端存储\n");
    else
        printf("我是大端存储\n");
    return 0;

}

你可能感兴趣的:(C语言,c++,算法,开发语言)