Java 字段在內(nèi)存中是小端存儲的,即低位字節(jié)在前试读,高位字節(jié)在后。
大小端的最小單位是字節(jié)荠耽,即大小端決定的是字節(jié)的排序钩骇。
而字節(jié)內(nèi)部的排序永遠(yuǎn)不受影響,永遠(yuǎn)都是高位在前铝量,低位在后倘屹。
驗(yàn)證
比如存儲一個(gè)int 類型的數(shù)據(jù),0x01020304慢叨,
如果是大端在前纽匙,則內(nèi)存中分布應(yīng)是 01 02 03 04
如果是小端在前,則內(nèi)存中分布應(yīng)是 04 03 02 01拍谐,驗(yàn)證下
try {
Field theUnsafe = Unsafe.class.getDeclaredField("theUnsafe");
theUnsafe.setAccessible(true);
Unsafe UNSAFE = (Unsafe) theUnsafe.get(null);
long a = UNSAFE.allocateMemory(4);
UNSAFE.putInt(a, 0x01020304);
//存放此int類型數(shù)據(jù)烛缔,實(shí)際存放占4個(gè)字節(jié),01,02,03轩拨,04
byte b = UNSAFE.getByte(a);
//通過getByte方法獲取剛才存放的int践瓷,取第一個(gè)字節(jié)
//如果是大端,int類型順序存放—》01,02,03,04 亡蓉,取第一位便是0x01
//如果是小端晕翠,int類型順序存放—》04,03,02,01 ,取第一位便是0x04
ByteOrder byteOrder = null;
switch (b) {
case 0x01:
byteOrder = ByteOrder.BIG_ENDIAN;
break;
case 0x04:
byteOrder = ByteOrder.LITTLE_ENDIAN;
break;
default:
assert false;
byteOrder = null;
}
System.out.println(byteOrder);
} catch (Exception e) {
e.printStackTrace();
}
// 輸出結(jié)果
LITTLE_ENDIAN