计算机中的大小端问题

简介: 1、大小端问题的由来在计算机内存中,通常是以字节(Byte),也就是 8 个位(Bit)为基本存储单元(也有以 16 位为基本存储单元的)。对于像C++中的char这样的数据类型,占用一个字节的大小,不会产生什么问题。

1、大小端问题的由来

在计算机内存中,通常是以字节(Byte),也就是 8 个位(Bit)为基本存储单元(也有以 16 位为基本存储单元的)。

对于像C++中的char这样的数据类型,占用一个字节的大小,不会产生什么问题。

但是当数据类型为int,在32bit的系统中,它需要占用4个字节(32bit),这个时候就会产生这4个字节在寄存器中的存放顺序的问题。比如int maxHeight = 0x12345678,&maxHeight = 0x0042ffc4。具体的该怎么存放呢?这个时候就需要理解计算机的大小端的原理了。

2、大小端的原理

大端:(Big-Endian):就是把数值的高位字节放在内存的低位地址上,把数值的低位字节放在内存的高位地址上。

小端:(Little-Endian):就是把数值的高位字节放在高位的地址上,低位字节放在低位地址上。

【注】不管是大端法还是小端法存储,计算机在内存中存放数据的顺序都是从低地址到高地址,所不同的是首先取低字节的数据存放在低地址还是取高字节数据存放在低地址。

        大端法和小端法指的是字节在内存中存储时的排列规则,而不是数据中的位的排列规则。也有以位序排列的机器,但很少见。另外,再次明确一下,大端法或小端法是数据在存储时的表现,而不是在寄存器中参与运算时的表现。

3、大小端比较

        我们常用的x86结构都是小端模式,而大部分DSP,ARM也是小端模式,不过有些ARM是可以选择大小端模式。所以对于上面的maxHeight是应该以小端模式来存放,具体情况请看下面两表。

(1)小端规则

img_0e3f918f9edc0d585a2c1b606b5bac0d.png

(2)大端规则

img_e4428597775d372caa99a33d20351364.png

        通过上面的表格,可以看出来大小端的不同。(注:其实在计算机内存中并不存在所谓的数据类型,比如char,int等的。这个类型在代码中的作用就是让编译器知道每次应该从那个地址起始读取多少位的数据,赋值给相应的变量。)

目录
相关文章
|
8月前
|
存储
计算机存储,字节分为大端和小端
计算机存储,字节分为大端和小端
104 1
|
2月前
|
存储
计算机进制转换
计算机进制转换
43 4
|
4月前
计算机使用的二进制
计算机使用的二进制
64 15
|
8月前
|
存储 算法 量子技术
计算机为什么采用二进制
计算机为什么采用二进制
1201 0
【408计算机组成原理】—字符与字符串(四)
【408计算机组成原理】—字符与字符串(四)
|
存储 编译器 C语言
计算机的大小端存储模式(计算机小白必看!)
本文将介绍计算机存储数据时的大小端问题
|
存储 编译器 C语言
【大小端问题】
大小端是什么? 计算机在内存存储中有两中存储模式: 大端字节序存储模式和小端字节序存储模式。 大端存储模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中。 小端存储模式,是指数据的低位保存在内存的低地址中,而数据的高位,保存在内存的高地址中。
|
存储 编译器 C语言
原反补及大小端
原反补及大小端
原反补及大小端
计算机组成原理——进制间相互转换
计算机组成原理——进制间相互转换
208 0
计算机组成原理——进制间相互转换