最近在看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. 根据该字节判断是否是高位或低位优先