青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

colorful

zc qq:1337220912

 

大端小端(Big- Endian和Little-Endian)

1/ 網絡字節順序是TCP/IP中規定好的一種數據表示格式,它與具體的CPU類型、操作系統等無關,從而可以保證數據在不同主機之間傳輸時能夠被正確解釋,網絡字節順序采用big-endian排序方式。
2/ 而我們常用的 x86 CPU (intel, AMD) 電腦是 little-endian,也就是整數的低位字節放在內存的低字節處。

舉個例子吧。假定你的數據是0x1234,
在網絡字節順序里 這個數據放到內存中就應該顯示成
addr addr+1
0x12 0x34
而在x86電腦上,數據0x1234放到內存中實際是:
addr addr+1
0x34 0x12
htons 的用處就是把實際主機內存中的整數存放方式調整成網絡字節順序。


------------------------------------------------------------------------------------------------------------

大端小端(Big- Endian和Little-Endian)

字節序(Endian),大端(Big-Endian),小端(Little-Endian) 圖文并茂

http://www.shnenglu.com/tx7do/archive/2009/01/06/71276.html

 http://my.oschina.net/alphajay/blog/5478

在 各種計算機體系結構中,對于字節、字等的存儲機制有所不同,因而引發了計算機 通信領 域中一個很重要的問題,即通信雙方交流的信息單元(比特、字節、字、雙字等等)應該以什么樣的順序進行傳送。如果不達成一致的規則,通信雙方將無法進行正 確的編/譯碼從而導致通信失敗。目前在各種體系的計算機中通常采用的字節存儲機制主要有兩種:Big-Endian和Little-Endian,下面先 從字節序說起。

 

一、什么是字節序

字節序,顧名思義字節的順序,再多說兩句就是大于一個字節類型的數據在內存中的存放順序(一個字節的數據當然就無需談順序的問題了)其實大部分人在實際的開 發中都很少會直接和字節序打交道。唯有在跨平臺以及網絡程序中字節序才是一個應該被考慮的問題。

在所有的介紹字節序的文章中都會提到字 節序分為兩類:Big-Endian和Little-Endian,引用標準的Big-Endian和Little-Endian的定義如下:
a) Little-Endian就是低位字節排放在內存的低地址端,高位字節排放在內存的高地址端
b) Big-Endian就是高位字節排放在內存的低地址端,低位字節排放在內存的高地址端
c) 網絡字節序:TCP/IP各層協議將字節序定義為Big-Endian,因此TCP/IP協議中使用的字節序通常稱之為網絡字節序。

1.1 什么是高/低地址端

首先我們要知道我們C程序映像中內存的空間布局情況:在《C專 家編程》中或者《Unix環境高級編程》中有關于內存空間布局情況的說明,大致如下圖:
----------------------- 最高內存地址 0xffffffff
棧底

棧頂

-----------------------

NULL (空洞)
-----------------------

-----------------------
未初始 化的數據
----------------------- 統稱數據段
初始化的數據
-----------------------
正 文段(代碼段)
----------------------- 最低內存地址 0x00000000

以上圖為例如果我們在棧 上分配一個unsigned char buf[4],那么這個數組變量在棧上是如何布局的呢?看下圖:
棧底 (高地址)
----------
buf[3]
buf[2]
buf[1]
buf[0]

----------
棧頂 (低地址)

1.2 什么是高/低字節

現在我們弄清了高/低地址,接著考慮高/低字節。有些文章中稱低位字節為最低有效位,高位字節為最高有效位。如果我們有一個32位無符號整型0x12345678,那么高位是什么,低位又是什么呢? 其實很簡單。在十進制中我們都說靠左邊的是高位,靠右邊的是低位,在其他進制也是如此。就拿 0x12345678來說,從高位到低位的字節依次是0x12、0x34、0x56和0x78
高/低地址端和高/低字節都弄清了。我們再來回顧 一下Big-Endian和Little-Endian的定義,并用圖示說明兩種字節序:
以unsigned int value = 0x12345678為例,分別看看在兩種字節序下其存儲情況,我們可以用unsigned char buf[4]來表示value:

Big-Endian: 低地址存放高位,如下圖:
棧底 (高地址)
---------------
buf[3] (0x78) -- 低位
buf[2] (0x56)
buf[1] (0x34)
buf[0] (0x12) -- 高位
---------------
棧頂 (低地址)

Little-Endian: 低地址存放低位,如下圖:
棧底 (高地址)
---------------
buf[3] (0x12) -- 高位
buf[2] (0x34)
buf[1] (0x56)
buf[0] (0x78) -- 低位
--------------
棧 頂 (低地址)

 

二、各種Endian

2.1 Big-Endian

計算機體系結構中一種描述多字節存儲順序的術語,在這種機制中最重要字節(MSB)存放在最低端的地址 上。采用這種機制的處理器有IBM3700系列、PDP-10、Mortolora微處理器系列和絕大多數的RISC處理器。
+----------+
| 0x34 |<-- 0x00000021
+----------+
| 0x12 |<-- 0x00000020
+----------+
圖 1:雙字節數0x1234以Big-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 |
+----------------------------------------+
圖 2:Big-Endian的bit序列編碼方式

2.2 Little-Endian

計算機體系結構中 一種描述多字節存儲順序的術語,在這種機制中最不重要字節(LSB)存放在最低端的地址上。采用這種機制的處理器有PDP-11、VAX、Intel系列 微處理器和一些網絡通信設備。該術語除了描述多字節存儲順序外還常常用來描述一個字節中各個比特的排放次序。

+----------+
| 0x12 |<-- 0x00000021
+----------+
| 0x34 |<-- 0x00000020
+----------+

圖3:雙字節數0x1234以Little-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 |
+-----------------------------------------+
圖 4:Little-Endian的bit序列編碼方式

注2:通常我們說的主機序(Host Order)就是遵循Little-Endian規則。所以當兩臺主機之間要通過TCP/IP協議進行通信的時候就需要調用相應的函數進行主機序 (Little-Endian)和網絡序(Big-Endian)的轉換

注3:正因為這兩種機制對于同一bit序列的序號編排方式恰 恰相反,所以《現代英漢詞典》中對MSB的翻譯為“最高有效位”欠妥,故本文定義為“最重要的bit/byte”。

2.3 Middle-Endian

除了Big-Endian和Little-Endian之外的多字節存儲順序就是Middle- Endian,比如以4個字節為例:象以3-4-1-2或者2-1-4-3這樣的順序存儲的就是Middle-Endian。這種存儲順序偶爾會在一些小 型機體系中的十進制數的壓縮格式中出現

嵌入式系統開發者應該對Little-endian和Big-endian模式非常了解。采用 Little-endian模式的CPU對操作數的存放方式是從低字節到高字節,而Big-endian模式對操作數的存放方式是從高字節到低字節。 32bit寬的數0x12345678在Little-endian模式CPU內存中的存放方式(假設從地址0x4000開始存放)為:

內存 地址 0x4000 0x4001 0x4002 0x4003
存放內容 0x78 0x56 0x34 0x12

 

而在Big- endian模式CPU內存中的存放方式則為:

內存地址 0x4000 0x4001 0x4002 0x4003
存放內容 0x12 0x34 0x56 0x78

 

三、Big-EndianLittle-Endian優缺點

Big-Endian優點:靠首先提取高位字節,你總是可以由看看在偏移位置為0的字節來確定這個數字是 正數還是負數。你不必知道這個數值有多長,或者你也不必過一些字節來看這個數值是否含有符號位這個數值是以它們被打印出來的順序存放的,所以從二進制到十進制的函數特別有效。因而,對于不同要求的機器,在設計存取方式時就會不同。

Little-Endian優點:提取一個,兩個,四個或者更長字節數據的匯編指令以與其他所有格式相同的方式進行:首先在偏移地址為0的地方提取最低位的字節,因為地址偏移和字節數是一對 一的關系,多重精度的數學函數就相對地容易寫了

如 果你增加數字的值,你可能在左邊增加數字(高位非指數函數需要更多的數字)。 因此, 經常需要增加兩位數字并移動存儲器里所有Big-endian順序的數字,把所有數向右移,這會增加計算機的工作量。不過,使用Little- Endian的存儲器中不重要的字節可以存在它原來的位置,新的數可以存在它的右邊的高位地址里。這就意味著計算機中的某些計算可以變得更加簡單和快速。

四、如何檢查處理器是Big-Endian還是Little-Endian?

由于聯合體union的存放順序是所有成員都從低地址開始存放,利用該特性就可以輕松地獲得了CPU對內存采用Little- endian還是Big-endian模式讀寫。例如:
int checkCPUendian(){
union {
unsigned int a;
unsigned char b;           
}c;
c.a = 1;
return (c.b == 1);      

}   /*return 1 : little-endian, return 0:big-endian*/

 

五、Big-EndianLittle-Endian轉 換

 

現有的平臺上Intel的X86采用的是Little-Endian,而像 Sun的SPARC采用的就是Big-Endian。那么在跨平臺或網絡程序中如何實現字節序的轉換呢?這個通過C語言的移位操作很容易實現,例如下面的 宏:

#if defined(BIG_ENDIAN) && !defined(LITTLE_ENDIAN)

#define htons(A)   (A)
#define htonl(A)     (A)
#define ntohs(A)   (A)
#define ntohl(A)    (A)

#elif defined(LITTLE_ENDIAN) && !defined(BIG_ENDIAN)

#define htons(A)     ((((uint16)(A) & 0xff00) >> 8) | \
(((uint16)(A) & 0x00ff) << 8))
#define htonl(A)     ((((uint32)(A) & 0xff000000) >> 24) | \
(((uint32)(A) & 0x00ff0000) >> 8) | \
(((uint32)(A) & 0x0000ff00) << 8) | \
(((uint32)(A) & 0x000000ff) << 24))
#define ntohs htons
#define ntohl htohl

#else

#error "Either BIG_ENDIAN or LITTLE_ENDIAN must be #defined, but not both."

 

 

網絡字節順序
1、字節內的比特位不受這種順序的影響
比如一個字節 1000 0000 (或表示為十六進制 80H)不管是什么順序其內存中的表示法都是這樣。

 

2、大于1個字節的數據類型才有字節順序問題
比如 Byte A,這個變量只有一個字節的長度,所以根據上一條沒有字節順序問題。所以字節順序是“字節之間的相對順序”的意思。


3、大于1個字節的數據類型的字節順序有兩種
比如 short B,這是一個兩字節的數據類型,這時就有字節之間的相對順序問題了。
網絡字節順序是“所見即所得”的順序。而Intel類型的CPU的字節順序與此相反。
比如上面的 short B=0102H(十六進制,每兩位表示一個字節的寬度)。所見到的是“0102”,按一般數學常識,數軸從左到右的方向增加,即內存地址從左到右增加的話,在內存中這個 short B的字節順序是:
01 02
這就是網絡字節順序。所見到的順序和在內存中的順序是一致的!
假設通過抓包得到網絡數據的兩個字節流為:01 02

而相反的字節順序就不同了,其在內存中的順序為:02 01

如果這表示兩個 Byte類型的變量,那么自然不需要考慮字節順序的問題。如果這表示一個 short 變量,那么就需要考慮字節順序問題。根據網絡字節順序“所見即所得”的規則,這個變量的值就是:0102

假設本地主機是Intel類型的,那么要表示這個變量,有點麻煩:
定義變量 short X,字節流地址為:pt,按順序讀取內存是為x=*((short*)pt);
那么X的內存順序當然是 01 02按非“所見即所得”的規則,這個內存順序和看到的一樣顯然是不對的,所以要把這兩個字節的位置調換。調換的方法可以自己定義,但用已經有的API還是更為方便。

網絡字節順序與主機字節順序
NBO 與HBO 網絡字節順序NBO(Network Byte Order):按從高到低的順序存儲,在網絡上使用統一的網絡字節順序,可以避免兼容性問題。主機字節順序(HBO,Host Byte Order):不同的機器HBO不相同,與CPU設計有關計算機數據存儲有兩種字節優先順序:高位字節優先和低位字節優先Internet上數據以高位字節優先順序在網絡上傳輸,所以對于在內部是以低位字節優先方式存儲數據的機器,在Internet上傳輸數據時就需要進行轉換。

htonl()
簡述:
    將主機的無符號長整形數轉換成網絡字節順序。
    #include <winsock.h>
    u_long PASCAL FAR htonl( u_long hostlong);
    hostlong:主機字節順序表達的32位數。
注釋:
    本函數將一個32位數從主機字節順序轉換成網絡字節順序。
返回值:
    htonl()返回一個網絡字節順序的值。

inet_ntoa()
簡述:
將網絡地址轉換成“.”點隔的字符串格式。
#include <winsock.h>
char FAR* PASCAL FAR inet_ntoa( struct in_addr in);
in:一個表示Internet主機地址的結構。
注釋:
本 函數將一個用in參數所表示的Internet地址結構轉換成以“.” 間隔的諸如“a.b.c.d”的字符串形式。請注意inet_ntoa()返回的字符串存放在WINDOWS套接口實現所分配的內存中。應用程序不應假設 該內存是如何分配的。在同一個線程的下一個WINDOWS套接口調用前,數據將保證是有效。
返回值:
若無錯誤發生,inet_ntoa()返回一個字符指針。否則的話,返回NULL。其中的數據應在下一個WINDOWS套接口調用前復制出來。

網 絡中傳輸的數據有的和本地字節存儲順序一致,而有的則截然不同,為了數據的一致性,就要把本地的數據轉換成網絡上使用的格式,然后發送出去,接收的時候也 是一樣的,經過轉換然后才去使用這些數據,基本的庫函數中提供了這樣的可以進行字節轉換的函數,如和htons( ) htonl( ) ntohs( ) ntohl( ),這里n表示network,h表示host,htons( ) htonl( )用于本地字節向網絡字節轉換的場合,s表示short,即對2字節操作,l表示long即對4字節操作。同樣ntohs( )ntohl( )用于網絡字節向本地格式轉換的場合。

 #endif

posted on 2012-05-17 10:13 多彩人生 閱讀(3209) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


導航

統計

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产欧美韩国高清| 夜夜嗨av色综合久久久综合网| 国产一区二区高清视频| 国产精品xnxxcom| 国产精品免费看片| 国产婷婷色综合av蜜臀av| 国产亚洲精品一区二555| 激情成人在线视频| 亚洲日本欧美| 亚洲在线第一页| 久久精品国产精品亚洲| 久久久噜噜噜久久| 亚洲国产精品电影在线观看| 亚洲二区精品| 正在播放亚洲| 久久久久久日产精品| 欧美精品一区二区三区高清aⅴ| 欧美日韩精品一区视频 | 欧美成人免费大片| 欧美久久久久| 国产精品一区视频网站| 在线观看欧美日韩| 亚洲视频一区二区在线观看| 久久高清国产| 亚洲精品影院在线观看| 性一交一乱一区二区洋洋av| 美女在线一区二区| 国产精品伦理| 最新日韩欧美| 久久国产精品久久久| 亚洲黄网站黄| 久久精品国产一区二区三| 欧美手机在线| 亚洲区免费影片| 久久精品国产亚洲一区二区三区 | 男同欧美伦乱| 国产欧美日韩免费| 亚洲色在线视频| 欧美激情视频给我| 久久精品国产v日韩v亚洲 | 亚洲第一精品久久忘忧草社区| 一区二区三区视频在线看| 免费观看成人网| 欧美在线影院在线视频| 国产精品久久网| 在线亚洲一区二区| 91久久香蕉国产日韩欧美9色| 欧美激情91| 中文国产亚洲喷潮| 久久天天综合| 亚洲欧美日韩一区二区三区在线| 欧美激情a∨在线视频播放| 黄色成人免费观看| 久久九九国产| 小辣椒精品导航| 国产精品羞羞答答| 亚洲一区二区欧美| 一区二区三区四区五区精品视频| 欧美福利视频在线| 亚洲国产精品成人久久综合一区| 久久久久久网| 久久久福利视频| 亚洲国产va精品久久久不卡综合| 麻豆91精品91久久久的内涵| 久久av一区| 一色屋精品视频在线看| 欧美成年人视频网站| 欧美a级大片| 日韩一区二区精品视频| 亚洲精选视频在线| 国产精品久久久久国产a级| 亚洲欧美精品suv| 亚洲欧美日韩一区二区三区在线| 国产有码在线一区二区视频| 久久五月天婷婷| 欧美**人妖| 亚洲一区二区三区精品视频| 一区二区三区精品久久久| 国产精品电影观看| 久久久精品欧美丰满| 久久欧美肥婆一二区| 亚洲国产欧美日韩精品| 亚洲精选一区| 国产在线麻豆精品观看| 欧美韩日精品| 国产精品久久久久久久免费软件| 久久av一区二区| 久久综合伊人77777蜜臀| 99亚洲一区二区| 午夜日韩激情| 99热精品在线| 久久成人精品| 9i看片成人免费高清| 亚洲欧美国产制服动漫| 亚洲国产精品va在线观看黑人 | 日韩亚洲欧美成人| 亚洲欧美综合国产精品一区| 亚洲成人在线观看视频| 亚洲美女91| 狠狠色狠狠色综合人人| 亚洲二区在线| 国产亚洲欧美日韩美女| 日韩视频在线播放| 国产精品视频网站| 午夜一区不卡| 欧美一区二区私人影院日本| 亚洲第一在线视频| 亚洲小说欧美另类社区| 亚洲欧洲三级| 午夜精品免费在线| 中文精品视频| 欧美~级网站不卡| 久久久久青草大香线综合精品| 欧美精品在线观看91| 另类酷文…触手系列精品集v1小说| 欧美揉bbbbb揉bbbbb| 牛牛影视久久网| 国产专区精品视频| 亚洲欧美中日韩| 亚洲欧美日韩人成在线播放| 欧美成人精品在线| 欧美激情一级片一区二区| 亚洲成色777777女色窝| 欧美大香线蕉线伊人久久国产精品| 亚洲免费久久| 国产一二三精品| 亚洲国产网站| 在线观看免费视频综合| 亚洲欧美国产毛片在线| 亚洲影视在线| 欧美日韩国产一中文字不卡| 欧美电影资源| 亚洲福利久久| 久久久综合网| 欧美高清视频一区二区三区在线观看 | 在线视频欧美日韩| 亚洲综合好骚| 国产精品欧美一区二区三区奶水| 亚洲精品在线观| 一区二区三区欧美视频| 欧美日韩综合不卡| 亚洲午夜久久久久久尤物| 亚洲网站在线| 国产精品久久久久久久久婷婷| 亚洲深夜福利| 久久成人18免费网站| 国产主播精品在线| 久久午夜羞羞影院免费观看| 免费视频最近日韩| 国产亚洲精品v| 亚洲激情中文1区| 欧美18av| 亚洲激情另类| 欧美色视频一区| 亚洲欧美激情在线视频| 久久久夜色精品亚洲| 激情五月婷婷综合| 欧美电影在线免费观看网站| 亚洲精品美女| 欧美亚洲三级| 精品福利电影| 欧美国产日韩一区二区在线观看| 亚洲精品美女久久7777777| 亚洲一区欧美激情| 国产视频在线观看一区| 欧美视频在线观看视频极品| 亚洲一区亚洲二区| 美乳少妇欧美精品| av不卡在线看| 国产伦理精品不卡| 欧美大片免费观看在线观看网站推荐| 亚洲精品中文字幕有码专区| 欧美一区午夜精品| 亚洲国产欧美精品| 国产麻豆日韩欧美久久| 狂野欧美激情性xxxx欧美| 亚洲最新视频在线播放| 久久在线免费观看视频| 在线午夜精品自拍| 在线成人av.com| 国产精品入口尤物| 欧美国产精品劲爆| 香蕉久久夜色精品国产| 亚洲经典视频在线观看| 久久米奇亚洲| 午夜精品久久久久影视| 亚洲三级电影在线观看| 国产亚洲电影| 欧美午夜精品| 欧美激情综合亚洲一二区| 久久精品日产第一区二区三区 | 亚洲免费影院| 亚洲精品免费在线播放| 国产视频自拍一区| 欧美日韩中文字幕| 欧美高清在线视频| 久久视频在线看| 午夜一区在线| 亚洲视频日本| 日韩午夜电影av|