最近在看Java原码的时候发现一个有趣的代码: 

Java代码
  1. static {
  2. long a = unsafe.allocateMemory(8);
  3. try {
  4. unsafe.putLong(a, 0x0102030405060708L);
  5. byte b = unsafe.getByte(a);
  6. switch (b) {
  7. case 0x01: byteOrder = ByteOrder.BIG_ENDIAN; break;
  8. case 0x08: byteOrder = ByteOrder.LITTLE_ENDIAN; break;
  9. default:
  10. assert false;
  11. byteOrder = null;
  12. }
  13. } finally {
  14. unsafe.freeMemory(a);
  15. }
  16. }
static {        long a = unsafe.allocateMemory(8);        try {            unsafe.putLong(a, 0x0102030405060708L);            byte b = unsafe.getByte(a);            switch (b) {            case 0x01: byteOrder = ByteOrder.BIG_ENDIAN;     break;            case 0x08: byteOrder = ByteOrder.LITTLE_ENDIAN;  break;            default:                assert false;                byteOrder = null;            }        } finally {            unsafe.freeMemory(a);        }    }
这里是判断底层的硬件是高位优先还是低位优先:
1. 首先分配一块内存
2. 然后将一个long存放到该内存区域
3. 从该内存区域中取出该数据的一个字节
4. 根据该字节判断是否是高位或低位优先