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

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>
            国产精品久久久久国产精品日日 | 国产精品一区视频| 欧美高清在线视频| 欧美风情在线观看| 欧美视频福利| 国产视频在线一区二区| 激情丁香综合| 亚洲三级影片| 亚洲欧美成人| 久久青草欧美一区二区三区| 欧美成人四级电影| 亚洲美女诱惑| 久久精品国产在热久久| 欧美福利影院| 国产精品网站在线观看| 亚洲国产精品999| 亚洲一区欧美| 蜜桃伊人久久| 亚洲午夜久久久久久久久电影网| 午夜精品一区二区三区在线视| 久久婷婷成人综合色| 欧美日韩一区二| 亚洲国产99精品国自产| 欧美专区在线| 欧美激情一区二区三区四区| 国产精品一区二区久激情瑜伽| 亚洲国产精品精华液网站| 亚洲欧美日韩高清| 亚洲国产精品va在线看黑人动漫| 日韩亚洲一区在线播放| 欧美一区二区播放| 欧美日韩一区二区三| 一区一区视频| 久久成年人视频| 亚洲精品视频一区| 欧美中文字幕在线播放| 欧美午夜一区二区| 一区二区欧美激情| 欧美大片91| 久久精品视频在线播放| 国产精品入口尤物| 亚洲视频在线观看视频| 亚洲国产精品久久久久秋霞蜜臀| 欧美一级视频| 国产精品久久777777毛茸茸| 99视频一区| 欧美激情网友自拍| 久久久精品国产免大香伊 | 亚洲国产日韩综合一区| 欧美gay视频| 久久九九国产| 国产一区二区精品久久91| 欧美在线观看视频一区二区| 9l国产精品久久久久麻豆| 久久永久免费| 国产一区二区三区四区老人| 亚洲中无吗在线| 夜夜狂射影院欧美极品| 欧美日韩国产va另类| 亚洲区一区二区三区| 欧美国产亚洲视频| 欧美成人伊人久久综合网| 亚洲国产精品久久久| 免费久久99精品国产自| 久久久久久91香蕉国产| 一区在线电影| 亚洲国产天堂久久综合网| 欧美ab在线视频| 99国产精品久久久| 日韩亚洲欧美精品| 欧美色视频日本高清在线观看| 99伊人成综合| 亚洲在线一区二区| 国产亚洲欧洲| 欧美高清一区二区| 欧美精品一区在线| 亚洲影院免费观看| 亚洲欧美日韩精品久久奇米色影视 | 嫩草影视亚洲| 一区二区高清在线观看| 中文日韩在线| 国产亚洲欧美日韩一区二区| 六月丁香综合| 欧美激情一二区| 亚洲一区美女视频在线观看免费| 亚洲一区在线直播| 亚洲第一视频网站| 亚洲娇小video精品| 国产精品国产三级国产aⅴ入口 | 欧美亚洲色图校园春色| 久久久久免费观看| 一区二区三区 在线观看视| 亚洲综合精品自拍| 亚洲精品欧美一区二区三区| a91a精品视频在线观看| 国产一区日韩欧美| 亚洲精品视频在线看| 国产欧美日本一区视频| 欧美国产乱视频| 国产九九精品| 亚洲区免费影片| 黄色免费成人| 亚洲欧美日韩在线播放| 日韩一区二区精品葵司在线| 欧美一区二区三区在线观看视频 | 欧美午夜精品电影| 国产一区清纯| 日韩视频一区二区在线观看 | 宅男噜噜噜66一区二区66| 在线播放精品| 午夜一级久久| 亚洲免费在线观看视频| 美女视频黄 久久| 久久久久久久久久久久久9999 | 欧美午夜精品| 亚洲韩国精品一区| 伊人一区二区三区久久精品| 亚洲一区二区三区在线| 妖精成人www高清在线观看| 久久蜜臀精品av| 久久久一区二区| 国产视频在线观看一区| 亚洲一区成人| 亚洲尤物在线| 欧美日韩黄视频| 亚洲另类自拍| 亚洲精品免费一区二区三区| 久久精品免费观看| 久久综合伊人77777蜜臀| 国产精品视频一区二区三区| 99在线观看免费视频精品观看| 99国产精品久久久久久久成人热 | 欧美电影打屁股sp| 激情综合在线| 另类专区欧美制服同性| 鲁大师影院一区二区三区| 国产亚洲精品久久久| 欧美一区二区在线播放| 久久久久久久久久久一区| 国产一区二区三区直播精品电影| 亚洲欧美日韩另类精品一区二区三区| 午夜在线不卡| 国产亚洲亚洲| 久久人人超碰| 亚洲国产一区二区三区高清| 亚洲电影第1页| 欧美成人a∨高清免费观看| 亚洲高清av| 一本久道久久综合狠狠爱| 欧美日韩在线播放三区| 亚洲午夜精品17c| 久久乐国产精品| 在线精品视频免费观看| 欧美成人精品三级在线观看 | 亚洲美女免费精品视频在线观看| 日韩亚洲欧美成人一区| 国产精品国产三级国产aⅴ无密码| 亚洲一区成人| 美女爽到呻吟久久久久| 亚洲精选视频在线| 欧美系列精品| 久久一二三区| 中日韩午夜理伦电影免费| 久久国产日韩欧美| 久久国产手机看片| 日韩视频精品| 国产精品久久久久9999| 欧美一区二区女人| 欧美国产日韩在线| 亚洲一区二区在| 激情一区二区三区| 欧美区日韩区| 久久精品99无色码中文字幕| 欧美国产一区二区| 香蕉视频成人在线观看 | 夜夜嗨av一区二区三区网站四季av| 国产精品国产亚洲精品看不卡15| 性欧美激情精品| 亚洲精品偷拍| 欧美xx视频| 欧美一区二区三区成人| 亚洲免费观看高清完整版在线观看| 国产精品日韩精品欧美在线| 玖玖国产精品视频| 欧美亚洲视频| 一区二区三区视频在线播放| 蜜桃精品久久久久久久免费影院| 亚洲欧美成人综合| 亚洲精品乱码久久久久久黑人| 国产日韩欧美日韩大片| 欧美久久精品午夜青青大伊人| 久久精品国产99精品国产亚洲性色| 亚洲精品日日夜夜| 欧美~级网站不卡| 久久精品人人做人人爽电影蜜月 | 国产一区二区在线观看免费| 欧美日韩一区不卡| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲欧美日本伦理| 这里只有精品电影|