字節序:
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, int offset) { 2 b[0 + offset] = (byte) (shortVal & 0xff); 3 b[1 + offset] = (byte) (shortVal >> 8 & 0xff); 4 } 5 6 public static short byteToShort_HL(byte[] b, int offset) 7 { 8 short result; 9 result = (short)((((b[offset + 1]) << 8) & 0xff00 | b[offset] & 0x00ff)); 10 return result; 11 } 12 13 public static void intToByte_LH(int intVal, byte[] b, int offset) { 14 b[0 + offset] = (byte) (intVal & 0xff); 15 b[1 + offset] = (byte) (intVal >> 8 & 0xff); 16 b[2 + offset] = (byte) (intVal >> 16 & 0xff); 17 b[3 + offset] = (byte) (intVal >> 24 & 0xff); 18 } 19 20 public static int byteToInt_HL(byte[] b, int offset) 21 { 22 int result; 23 result = (((b[3 + offset] & 0x00ff) << 24) & 0xff000000) 24 | (((b[2 + offset] & 0x00ff) << 16) & 0x00ff0000) 25 | (((b[1 + offset] & 0x00ff) << 8) & 0x0000ff00) 26 | ((b[0 + offset] & 0x00ff)); 27 return result; 28 }
int 的高低位:
(1) 獲取高字節,低字節。
1 // 分別取出int的高字節跟低字節 2 int value = 515; 3 int big = (value & 0xFF00) >> 8; 4 int little = value & 0xFF;
(2)根據高字節,低字節,為int指定。
1 // 為int設置指定的高字節跟低字節 2 int value; 3 int a; int b; 4 value= (a<< 8) | (b & 0xFF);