字節序:
1、Big-Endian(大端模式)
Big-Endian就是高位字節排放在內存的低地址端,低位字節排放在內存的高地址端。
2、Little-Endian (小端模式)
Little-Endian就是低位字節排放在內存的低地址端,高位字節排放在內存的高地址端。
大小端模式:
在操作系統中,x86和一般的OS(如windows,FreeBSD,Linux)使用的是小端模式。但比如Mac OS是大端模式。
1、不同端模式的處理器進行數據傳遞時必須要考慮端模式的不同(因主機CPU不同,不同的機器會出現高、低兩種字節序問題)。
2、在網絡上傳輸數據時,由於數據傳輸的兩端對應不同的硬件平台,采用的存儲字節順序可能不一致。所以在TCP/IP協議規定了在網絡上必須采用網絡字節順序,也就是大端模式。對於char型數據只占一個字節,無所謂大端和小端。而對於非char類型數據,必須在數據發送到網絡上之前將其轉換成大端模式。接收網絡數據時按符合接受主機的環境接收。
存儲量大於1字節,非char類型,如int,float等,要考慮字節的順序問題了。
java由於虛擬機的關系,屏蔽了大小端問題。
1. 網絡字節序是高字節序序
2. C++是主機字節序(高、低都有可能)
3. JAVA是網絡字節序、也就是高字節序
java 端,大小端轉換:
其它多余1字節類型可以參考變形寫出即可
1 public static void shortToByte_LH(short shortVal, byte[] b, intoffset) {2 b[0 + offset] &#