`

字节序(Endian),大端(Big-Endian),小端(Little-Endian)

阅读更多

字节序(Endian),大端(Big-Endian),小端(Little-Endian) 在各种计算机体系结构中,对于字节、字等的存储机制有所不同,因而引发了计算机通信领域中一个很重要的问题,即通信双方交流的信息单元(比特、字节、字、双字等等)应该以什么样的顺序进行传送。如果不达成一致的规则,通信双方将无法进行正确的编/译码从而导致通信失败。目前在各种体系的计算机中通常采用的字节存储机制主要有两种: Big-Endian和Little-Endian。 字节顺序(Endian) 现代的计算机系统一般采用字节(Octet, 8 bit Byte)作为逻辑寻址单位。当物理单位的长度大于1个字节时,就要区分字节顺序(Byte Order, or Endianness)。常见的字节顺序有两种:Big Endian(High-byte first)和Little Endian(Low-byte first),这就是表1中的BE和LE。Intel X86平台采用Little-Endian,而PowerPC处理器则采用了Big-Endian。 词源:据Jargon File记载,endian这个词来源于Jonathan Swift在1726年写的讽刺小说 "Gulliver's Travels"(《格利佛游记》)。该小说在描述Gulliver畅游小人国时碰到了如下的一个场景。在小人国里的小人因为非常小(身高6英寸)所以总是碰到一些意想不到的问题。有一次因为对水煮蛋该从大的一端(Big-End)剥开还是小的一端(Little-End)剥开的争论而引发了一场战争,并形成了两支截然对立的队伍:支持从Big-End剥开的人Swift就称作Big-Endians而支持从Little-End剥开的人就称作Little-Endians……(后缀ian表明的就是支持某种观点的人:-)。Endian这个词由此而来。 1980年,Danny Cohen在其著名的论文"On Holy Wars and a Plea for Peace"中为了平息一场关于在消息中字节该以什么样的顺序进行传送的争论而引用了该词。该文中,Cohen非常形象贴切地把支持从一个消息序列的MSB开始传送的那伙人叫做Big-Endians,支持从LSB开始传送的相对应地叫做Little-Endians。此后Endian这个词便随着这篇论文而被广为采用。 Mapping registers to memory locations 最高有效位 MSB: Most Significant Bit 最高有效位(MSB),有时候叫做最左边的位,是在一个n位二进制数字中的n-1位,这个位有最高的权重(2^(n-1))。第一个或最左边的位,当这个数字被用一般的方式书写时。 最低有效位 LSB: Least Significant Bit 最低有效位(LSB)是给这些单元值的一个二进制整数位位置,就是,决定是否这个数字是偶数或奇数。LSB有时候是指最右边的位,因为写较不重要的数字到右边位置符号的协定。它类似于一个十进制整数的最不重要的数字,它是在一个(最右边)位置的数字。 大端Big-Endian 低地址存放最高有效位(MSB),既高位字节排放在内存的低地址端,低位字节排放在内存的高地址端。 计算机体系结构中一种描述多字节存储顺序的术语,在这种机制中最高有效位(MSB)存放在最低端的地址上。采用这种机制的处理器有IBM3700系列、PDP-10、Motorola微处理器系列和绝大多数的RISC处理器。 小端Little-Endian 低地址存放最低有效位(LSB),既低位字节排放在内存的低地址端,高位字节排放在内存的高地址端。 计算机体系结构中一种描述多字节存储顺序的术语,在这种机制中最不重要字节(LSB)存放在最低端的地址上。采用这种机制的处理器有PDP-11、VAX、Intel系列微处理器和一些网络通信设备。该术语除了描述多字节存储顺序外还常常用来描述一个字节中各个比特的排放次序。 中端 Middle-Endian 除了big-endian和little-endian之外的多字节存储顺序就是middle-endian,比如以4个字节为例:象以3-4-1-2或者2-1-4-3这样的顺序存储的就是middle-endian。这种存储顺序偶尔会在一些小型机体系中的十进制数的压缩格式中出现。 网络字节序 Network Order TCP/IP各层协议将字节序定义为Big-Endian,因此TCP/IP协议中使用的字节序通常称之为网络字节序。 主机序 Host Order 它遵循Little-Endian规则。所以当两台主机之间要通过TCP/IP协议进行通信的时候就需要调用相应的函数进行主机序(Little-Endian)和网络序(Big-Endian)的转换。 C++怎样判别大端小端 方法一:使用宏的方法 const int endian = 1; #define is_bigendian () ((*(char*) &endian) == 0) #define is_littlendbian () ((*(char*) &endian) == 1) 方法二: Bool IsLittleEndian () { Union { long val; char Char[sizeof(long)]; } u; u.val = 1; // 1-小端(Intel); 0-大端(Motor) if (u.Char [0] == 1) { return true; // 小端 } else if (u.Char [sizeof (long)-1] == 1) { return false; // 大端 } throw ( "Unknown!" ); }

附:常见Processor, OS的byte ordering情况

Processor OS Order
x86 (INTEL, AMD, … ) All little-endian
DEC ALPHA All little-endian
HP-PA NT little-endian
HP-PA UNIX big-endian
SUN SPARC All? big-endian
MIPS NT little-endian
MIPS UNIX big-endian
PowerPC NT little-endian
PowerPC non-NT big-endian
RS/6000 UNIX big-endian
MOTOROLA m68k All big-endian

分享到:
评论

相关推荐

    大端(Big Endian)与小端(Little Endian)简介

    这些字节如何在内存中排列,涉及到两种主要的存储方式——大端(Big Endian)与小端(Little Endian)。本文将深入探讨这两种存储方式的概念、原理及其应用场景。 #### 二、大端与小端的定义 1. **大端表示法(Big...

    字节存储顺序: little-endian小端,big-endian大端 教程

    你是否遇到过,内存中的数据顺序颠倒 你存入1234,实际存储的是3412. 字节存储顺序: little-endian小端,big-endian大端 教程 主机序,网络序 hton,ntoh

    大端(Big_Endian)与小端(Little_Endian)简介

    在计算机科学领域,大端(Big Endian)与小端(Little Endian)指的是数据(特别是多字节整数)在内存中存储时的字节顺序。这两种表示方法主要应用于不同类型的计算机体系结构中,对软件开发尤其是跨平台编程具有...

    Big-and-Little-Endian.rar_LIt_endian_little

    在计算机科学中,大端字节序(Big-Endian)和小端字节序(Little-Endian)是两种主要的数据存储方式,对于理解和编写跨平台应用程序的开发者来说至关重要。这两种字节序涉及到如何在内存中存储多字节数据类型,如...

    大端序和小端序

    大端序和小端序是计算机科学中的一种概念,用于描述多字节数据在内存中的存储顺序。这种顺序对于跨平台和网络程序非常重要,因为不同的平台和网络协议可能使用不同的字节序。 字节序可以分为两类:Big-Endian 和 ...

    西门子PLC接口,大端和小-Endian的存储格式.pdf

    西门子PLC接口,大端和小-Endian的存储格式pdf,西门子PLC接口,大端和小-Endian的存储格式:本文介绍了SINUMERIK:PLC接口,和Little-Endian的Big-Endian的存储格式

    解析大端模式和小端模式

    目前主要存在两种字节序类型:大端模式(Big Endian)与小端模式(Little Endian)。这两种模式直接影响着程序在不同系统之间的兼容性以及网络通信中数据包的解码。 #### 大端模式(Big Endian) 大端模式是指在多...

    Little_Big_endian.rar_big endian_little

    这里我们主要讨论两种字节顺序:大端字节序(Big-endian)和小端字节序(Little-endian)。这两个术语源自Gulliver's Travels中的两个部落名称,用来形象地描述数据在内存中的排列方式。 标题“Little_Big_endian....

    little endian,big endian 小端存储、大端存储.zip

    little endian,big endian 小端存储、大端存储.zip

    如何提取大端存储(Big-Endian)二进制文件中的数据,并输出到txt中

    如何提取大端存储(Big-Endian)二进制文件中的数据,并输出到txt中。matlab实现

    浅学字节序——字节序大小端,主机字节序,网络字节序的理解

    #### 小端字节序(Little-Endian) 与大端字节序相反,在小端字节序中,数据的低位字节被存放在内存的低地址端,而高位字节被存放在内存的高地址端。以同样的32位数据0x12345678为例,在小端字节序中将被存储为:...

    TIA博途-32位浮点数大小端存储-高低字节转换全局FB库文件(4种字节排列顺序)-V17版本.zip

    计算机内部是以二进制形式存储数据的,对于多字节的数据类型(如32位浮点数),其字节的排列顺序有两种方式:大端模式(Big-Endian)和小端模式(Little-Endian)。大端模式是指最高有效字节(也称为高字节或MSB,...

    JAVA网络字节序转换1

    主要有两种字节序:Big-Endian(大端字节序)和 Little-Endian(小端字节序)。 1. **大端字节序(Big-Endian)**: 大端字节序是指数据的最高有效字节存储在最低地址。例如,4字节的数字0x01020304,在Big-Endian...

    Big Endian & Little Endian.pdf

    本文旨在详细介绍两种常见的数据存储格式:Big Endian(大端模式)与Little Endian(小端模式),并探讨它们在实际应用中的重要性。 #### 二、基本概念 **Big Endian** 和 **Little Endian** 是指多字节数据(如...

    字符编码转换 Text、ANSI、Unicode、Unicode Big Endian、UTF-8、UTF-7

    Little Endian(小端序)是低字节在前,高字节在后;Big Endian(大端序)则相反。在标题中提到的“Unicode”通常指Little Endian的UTF-16编码,而“Unicode Big Endian”则是Big Endian的UTF-16编码。 4. **UTF-8...

    网络字节序和主机字节序

    常见的有两种字节序:Little Endian(小端字节序)和 Big Endian(大端字节序)。Little Endian 将低序字节存储在起始地址,而 Big Endian 将高序字节存储在起始地址。 Little Endian 最符合人的思维的字节序,因为...

    TIA博途-32位浮点数大小端存储-高低字节转换的具体方法示例(4种字节排列顺序).docx

    字节顺序分为大端字节序(Big-Endian)和小端字节序(Little-Endian),这两种字节序决定了多字节数值在内存中的排列方式。在TIA博途中,理解和掌握这些概念对于正确处理数据传输和程序设计至关重要。 首先,我们要...

    Macro-test-mode-test-system.zip_endian_little endian

    Endianness 主要分为两种:大端法(Big Endian)和小端法(Little Endian)。这个名为 "Macro-test-mode-test-system.zip_endian_little_endian" 的压缩包文件是为了帮助用户检测他们的个人计算机(PC)使用的是哪种...

    本地字节序和网络字节序.pdf

    2. **大端字节序(Big Endian)**:与小端相反,大端字节序中高位字节存储在内存的低地址处,而低位字节则存于高地址处。十六进制数`0x12345678`在大端模式下会存储为`12 34 56 78`。Motorola 68k和PowerPC等处理器...

Global site tag (gtag.js) - Google Analytics