先看一段代碼:
@Test public void test(){ byte a = -5; byte b = 12; System.out.println(a); System.out.println(Integer.toHexString(a)); System.out.println(Integer.toHexString(a & 0xff)); System.out.println(b); System.out.println(Integer.toHexString(b)); System.out.println(Integer.toHexString(b & 0xff)); }
執行結果:
-5 fffffffb fb 12 c c
解釋:
1.負數在計算機中以補碼形式保存,所以-5的二進制表示為11111011(負數補碼的計算方式:絕對值的反碼+1)
2.byte轉換為int時,左邊的24位補符號位,對於-5,轉換后的二進制表示為11111111111111111111111111111011,這與之前的11111011,十進制都表示為-5,所以輸出為-5
3.0xff為一個int整數,255,二進制表示為00000000000000000000000011111111,-5 & 0xff,即將-5的高24位置0
4.Integer.toHexString函數,循環右移,每次取4位,轉換為16進制字符串,所以11111111111111111111111111111011轉成16進制字符串,前面出現多次的'1111'都轉成了'f'
Integer.toHexString源碼如下:
/** * Convert the integer to an unsigned number. */ //shift=4 private static String toUnsignedString(int i, int shift) { char[] buf = new char[32]; int charPos = 32; int radix = 1 << shift; int mask = radix - 1; do { buf[--charPos] = digits[i & mask]; i >>>= shift; } while (i != 0); return new String(buf, charPos, (32 - charPos)); } /** * All possible chars for representing a number as a String */ final static char[] digits = { '0' , '1' , '2' , '3' , '4' , '5' , '6' , '7' , '8' , '9' , 'a' , 'b' , 'c' , 'd' , 'e' , 'f' , 'g' , 'h' , 'i' , 'j' , 'k' , 'l' , 'm' , 'n' , 'o' , 'p' , 'q' , 'r' , 's' , 't' , 'u' , 'v' , 'w' , 'x' , 'y' , 'z' };