字节的存储顺序
⑴ 计算机的字节是怎样存储的
1、一般的数据存储是“高高低低”存储方式。
2、比如一个整数占4个字节,其中的高位数所占字节在高位字节,其低位数所占字节在低位字节,即高位数占高字节,低位数占低字节。
3、以整数129为例,要占4个字节,为(0000 0000 0000 0000 0000 0001 0000 0001),四个字节的真棚绝液实存储时,像0000 0001是最低位的字节,存在最前面,像在它之前的三个字,会依次在这些字节的后边,即地址号更大。
(1)字节的存储顺序扩展阅读:
通常我们从最高有效位(most significant digit)开始自左向右书写一个数字。在理解有效位这个概念时,可以想象一下支票数额的第一位增加1和最后一位增加1之间的巨大区别,前者肯定会让自己喜出望外。
计算机内存中一个字节的位相当于二进制数的位,这意味着最低有效位表示1,倒数第二个有效位表示2×1或2,倒数第三个有效位表示2×2×1或宏毁4,依次类推。
如果用内存中的两个字节表示一个16位的数,那么其中的一个字节将存放最低的8位有效位链物,而另一个字节将存放最高的8位有效位,见图10.5。
⑵ Big Endian与Little Endian字节存储顺序
不同的CPU有不同的字节序类型,这些字节序是指整数在内存中保存的顺序。分为小端格式和大端格式(Little-Endian&Big-Endian):
比如0x1234; 低8位是34,高8位是12;如果它们分配的内存其实地址是0x0001,
那么如果是大端存储,那么0x0001内存低位地址存放高位字节12;如果是小端存储,那么0x0001内存低位地址存放低位字节34,0x0002存放12。
据Jargon File记载,endian这个词来源于Jonathan Swift在1726年写的讽刺小说 "Gulliver's Travels"(《格利佛游记》)。该小说在描述Gulliver畅游小人国时碰到了如下的一个场景。在小人国里的小人因为非常小(身高6英寸)所以总是碰到一些意想不到的问题。有一次因为对水煮蛋该从大的一端(Big-End)剥开还是小的一端(Little-End)剥开的争论而引发了一场战争,并形成了两支截然对立的队伍:支持从大的一端剥开的人Swift就称作Big-Endians,而支持从小的一端剥开的人就称作Little-Endians......(后缀ian表明的就是支持某种观点的人)。
1980年,Danny Cohen在其着名的论文"On Holy Wars and a Plea for Peace"中为了平息一场关于在消息中字节该以什么样的顺序进行传送的争论而引用了该词。该文中,Cohen非常形象贴切地把支持从一个消带含息序列的最高位开始传送的那伙人叫做Big-Endians,支持从最低位开始传送的相对应地叫做Little-Endians。此后Endian这个词便随着这篇论文而被广为采用。
little endian和big endian是表示计算机字节顺序的两种格式,所谓的字节顺序指的是长度跨越多个字节的数据的存放形式.
假设从地址0x00000000开始的一个字中保存有数据0x1234abcd,那么在两种不同的内存顺序的机器上从字节的角度去看的话分别表示为:
需要特别说明的是,以上假设机器是每个内派行悄存单元以8位即一个字节为单位的. 简单的说,little endian把低字节存放在内存的低位;而big endian将低字节存放在内存的高位.
现在主流的CPU,intel系列的是采用的little endian的格式存放数据,而motorola系列的CPU采用的是big endian.
比如: int x, 它的地址为0x100。 那么它占据了内存中的Ox100, 0x101, 0x102, 0x103这四个字节(32位系统,所以int占用4个字节)。
上面只是内存字节组织的一种情况: 多字节对象在内存中的组织有一般有两种约定。 考虑一个W位的整数。它的各位表达如下:
Xw-1, Xw-2, ... , X1, X0,它的
MSB (Most Significant Byte, 最高有效字节)为 Xw-1, Xw-2, ... Xw-8;
LSB (Least Significant Byte, 最低有效字节)为 X7,X6,..., X0。
其余的字节位于MSB, LSB之间。
这就引出了大端(Big Endian)与小端(Little Endian)的问题。如果LSB在MSB前面, 既LSB是低地址, 则该机器是小端; 反之则是大端。
对于数据中跨越多个字节的对象, 我们必须为尘渣它建立这样的约定:
对于跨越多个字节的对象,一般它所占的字节都是连续的,它的地址等于它所占字节最低地址。(链表可能是个例外, 但链表的地址可看作链表头的地址)。
import java.nio.ByteOrder;
⑶ 字节顺序的介绍
字节顺竖颤序是指占内存多于一个字节类型的数据在内存中的存放顺序,通常有小端、大端两种字节顺序。小端字节序指低字节数据存放在内存低地址处,高字节数据存放在内存高地址处;大端字节序是高字节数据存放在低地址处,低字节数仿历据存放在高余大败地址处。
⑷ 计算机存储是低位在前高位在后吗应该怎么区分16进制中哪个是高位哪个是低
计算机存储:最小单位是字节,存储顺序(小端模式)为低位字节在前、高位在后
16进制销轮:中最右边的是最低位,标记为第0位,向左边一位是第1位,这样一直到这个数据的第15位。