一文让你快速了解【大小端概念】!

发布于:2023-01-24 ⋅ 阅读:(16) ⋅ 点赞:(0) ⋅ 评论:(0)

0.在介绍大小端之前呢,我们先来看一道题目

在这里插入图片描述
首先为什么会输出11223300呢,可能大家会觉得输出的是00223344,那结果究竟为什么不一样呢?

1.这里就要引入一个概念:什么是大小端?

大端字节序存储:把一个数值的低位字节的内容,存放到高地址处,高位字节的内容,存放到低地址处。
小端字节序存储:把一个数值的低位字节的内容,存放到低地址处,高位字节的内容,存放到高地址处。

1.1 按F10进行调试,然后打开内存窗口

在这里插入图片描述

1.2 通过&a找到a的地址

在这里插入图片描述
在这里插入图片描述

很明显从这里看出在VS2019下,采用的是小端存储,数值低位字节的内容的存放在低地址处数值高位的字节内容存放在高地址处

2 为什么要有大小端呢?

为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位的,每个地址单元
都对应着一个字节,一个字节为8 bit。但是在C语言中除了8 bit的char之外,还有16 bit的short
型,32 bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32
位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。因
此就导致了大端存储模式和小端存储模式。
例如:一个 16bit 的 short 型 x ,在内存中的地址为 0x0010 , x 的值为 0x1122 ,那么 0x11 为
高字节, 0x22 为低字节。对于大端模式,就将 0x11 放在低地址中,即 0x0010 中, 0x22 放在高
地址中,即 0x0011 中。小端模式,刚好相反。我们常用的 X86 结构是小端模式,而 KEIL C51 则
为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式
还是小端模式。
在这里插入图片描述

3.一道笔试题(2015年百度系统工程师笔试题)

请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序。

#include <stdio.h>
int check_sys()
{
     int i = 1;
     return (*(char *)&i);
}
int main()
{
     int ret = check_sys();
     if(ret == 1)
     {
         printf("小端\n");
     }
     else
     {
         printf("大端\n");
     }
     return 0; 
 }

那么为什么这么判断呢,我们接下来做分析!

3.1 看图

在这里插入图片描述
我们假设一个变量a=1,然后取出a的地址,将它强制转换成char * ,用char*p来接收,指向低地址处的一个字节,然后我们将解引用,如果返回的是1,则是小端存储,返回0,则是大端存储!

4.结语

大家听懂了吗?喜欢就点个赞呗!
在这里插入图片描述