首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 编程语言 > C/C++ > Origin of Endian
【标  题】:Origin of Endian
【关键字】:Origin,of,Endian
【来  源】:http://www.cublog.cn/u/17855/showart.php?id=104726

Origin of Endian

                                  Endian的由来

                          ============================

                            NightOwl(zjwu@bigfoot.com)

                                   2002/07/16

                          ============================

 

一、引子

  在各种计算机体系结构中,对于字节、字等的存储机制有所不同,因而引发了计算机通信领域中一个很重要的问题,即通信双方交流的信息单元(比特、字节、字、双字等等)应该以什么样的顺序进行传送。如果不达成一致的规则,通信双方将无法进行正确的编/译码从而导致通信失败。目前在各种体系的计算机中通常采用的字节存储机制主要有两种:

      big-edianlittle-endian

  本文简要描述这两种存储机制的来历、特点和区别。

  

  为了叙述方便,下面先对本文中将要用到的两个术语做简单的定义。

  1MSB

  MSBMost Significant Bit/Byte的首字母缩写,通常译为最重要的位或者最重要的字节。它通常用来表明在一个bit序列(如一个byte8bit组成的一个序列)或者一个byte序列(如word是两个byte组成的一个序列)中对整个序列取值影响最大的那个bit/byte

  2LSB

  LSBLeast Significant Bit/Byte的首字母缩写,通常译为最不重要的位或者最不重要的字节。它通常用来表明在一个bit序列(如一个byte8bit组成的一个序列)或者一个byte序列(如word是两个byte组成的一个序列)中对整个序列取值影响最小的那个bit/byte

 

二、endian的来由

  1Definition

      endian: The ordering of bytes in a multi-byte number.

      定义:在计算机系统体系结构中用来描述在多字节数中各个字节的存储顺序。

  2Etymology

  The term comes from Swift's "Gulliver's Travels" via the famous paper"On Holy Wars and a Plea for Peace" by Danny Cohen, USC/ISI IEN 137, 1980-04-01.

  The Lilliputians, being very small, had correspondingly small political problems. The Big-Endian and Little-Endian parties debated over whether soft-boiled eggs should be opened at the big end or the little end.[From: Free On-Line Dictionary Of Computing or Jargon File]

  词源:据Jargon File记载,endian这个词来源于Jonathan Swift1726年写的讽刺小说 "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这个词便随着这篇论文而被广为采用。

  

三、各种endian

  1big-endian

  A computer architecture in which, within a given multi-byte numeric representation, the most significant byte has the lowest address (the word is stored "big-end-first").

  Most processors, including the IBM 370 family, the PDP-10, the Motorola microprocessor families, and most of the various RISC designs current in mid-1993, are big-endian. [From: Free On-Line Dictionary Of Computing or Jargon File]

  

  big-endian:计算机体系结构中一种描述多字节存储顺序的术语,在这种机制中最重要字节(MSB)存放在最低端的地址上。采用这种机制的处理器有IBM3700系列、PDP-10Mortolora微处理器系列和绝大多数的RISC处理器。

  

                                +----------+

                                |   0x34   |<-- 0x00000021

                                +----------+

                                |   0x12   |<-- 0x00000020

                                +----------+

 

  图1:双字节数0x1234big-endian的方式存在起始地址0x00000020

 

  在Big-Endian中,对于bit序列中的序号编排方式如下(以双字节数0x8B8A为例):

                  bit   0 1 2 3 4 5 6 7   8 9 10 11 12 13 14 15

                      +----------------------------------------+

                  val | 1 0 0 0 1 0 1 1 | 1 0 0  0  1  0  1  0 |

                      +----------------------------------------+

                        ^   0x8B                 0x8A        ^

                       MSB                                  LSB

2Big-Endianbit序列编码方式

 

  注1:通常在TCP/IP协议栈所说的网络序(Network Order)就是遵循Big-Endian规则。在TCP/IP网络通信中,通信双方把消息按照如图2的方式进行编码,然后按从MSB(Bit0)LSB的顺序在网络上传送。

  

  2little-endian

  <data, architecture> A computer architecture in which, within a given 16- or 32-bit word,bytes at lower addresses have lower significance (the word is stored "little-end-first"). The PDP-11 and VAX families of computers and Intel microprocessors and a lot of communications and networking hardware are little-endian.

  The term is sometimes used to describe the ordering of units other than bytes; most often, bits within a byte. [From: Free On-Line Dictionary Of Computing or Jargon File]

  little-endian:计算机体系结构中一种描述多字节存储顺序的术语,在这种机制中最不重要字节(LSB)存放在最低端的地址上。采用这种机制的处理器有PDP-11VAXIntel系列微处理器和一些网络通信设备。该术语除了描述多字节存储顺序外还常常用来描述一个字节中各个比特的排放次序。

 

                                +----------+

                                |   0x12   |<-- 0x00000021

                                +----------+

                                |   0x34   |<-- 0x00000020

                                +----------+

3:双字节数0x1234little-endian的方式存在起始地址0x00000020

 

  在Little-Endian中,对于bit序列中的序号编排和Big-Endian刚好相反,其方式如下(以双字节数0x8B8A为例):

 

               bit   15 14 13 12 11 10 9 8   7 6 5 4 3 2 1 0

                   +-----------------------------------------+

               val | 1  0  0  0  1  0  1 1 | 1 0 0 0 1 0 1 0 |

                   +-----------------------------------------+

                     ^      0x8B                   0x8A    ^

                    MSB                                   LSB

4Little-Endianbit序列编码方式

 

  注2:正因为这两种机制对于同一bit序列的序号编排方式恰恰相反,所以《现代英汉词典》中对MSB的翻译为“最高有效位”欠妥,故本文定义为“最重要的bit/byte”。

 

  3middle-endian

<data, architecture> Neither big-endian nor little-endian. Used of perverse byte orders such as 3-4-1-2 or 2-1-4-3, occasionally found in the packed decimal formats of some minicomputer manufacturers.[From: Free On-Line Dictionary Of Computing or Jargon File]

middle-endian:除了big-endianlittle-endian之外的多字节存储顺序就是middle-endian,比如以4个字节为例:象以3-4-1-2或者2-1-4-3这样的顺序存储的就是middle-endian。这种存储顺序偶尔会在一些小型机体系中的十进制数的压缩格式中出现。

 

四、收尾

要详细解释这两种编码顺序已经超出本文所涉及的内容,如果你有兴趣的话可以参考上面提及的Danny Cohen的论文("On Holy Wars and a Plea for Peace"),该论文详细的描述了这两种编码顺序的历史、所基于的数学理论和各自拥护者争论的焦点等知识,绝对可以大饱你打破沙锅问到底的内心需要。

 

五、References & WebLinks

1.  Free On-Line Dictionary Of Computing

[http://foldoc.doc.ic.ac.uk/foldoc/index.html]

2.  Jargon File [http://info.astrian.net/jargon/]

3.  Gulliver's Travels《格利佛游记》 [http://www.jaffebros.com/lee/gulliver/]

4.  On Holy Wars and a Plea for Peace

[http://khavrinen.lcs.mit.edu/wollman/ien-137.txt]


原文下载
补发·程序·图片:【上一篇】
socket编程成功示例:【下一篇】
【相关文章】
  • Java Services Orchestration for Actions(J-SOFA )
  • SDS做过soft partition后磁盘的更换
  • communication of parent process and child process
  • lsof,linux和unix下的一个诊断分析工具
  • 神秘人物登场 KOF惊现《卓越之剑GE》
  • The Rule of Method Design
  • Example of Grsecurity protection avoid.
  • 用OpenOffice玩StarWars游戏
  • 针对 UNIX 的 Microsoft Windows 安全和目录服务解决方案指南
  • [J2ME Q&A]MMAPI"Cannot parse this type of AMR"异常之讨论
  • 【随机文章】
  • DS6800连接AIX时vpath常见问题解答
  • Grub VS windows
  • jsp路径问题(例子:留言本下读取图片)
  • Firewall Questions for beginners
  • 利用Windows注册表存储信息
  • 欢迎广大Ldap高手赐教。
  • 关于在qt中如何连接sqlite3数据库的问题
  • Session Fa?ade模式
  • 前世谁埋的你?
  • 网吧的一般限制破解
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 软讯网络 All Rigths Reserved.