(1)n=37 ,二進制數就是 100101
因為在Java中,所有數據的表示方式都是以補碼形式來表示,如果沒有特別的說明,Java 中的數據類型默認為int,int數據類型的長度為8位,就是32字節,32bit的意思,因此,n=100101的原碼=補碼(因為是正數,所以原=補=反)運算過程就是:
原碼:00000000 00000000 00000000 00100101 =37
~n(對n的原碼) 取反運算得: 11111111 11111111 11111111 11011010 很明顯,最高位是1,意思是原碼為負數,負數的補碼是其絕對值的原碼取反,末尾再加1,因此,我們可將這個二進制數的補碼進行還原:
首先,末尾減1得反碼:11111111 11111111 11111111 11011001
其次,將各位取反得原碼:00000000 00000000 00000000 00100110 這個就是~n的絕對值形式,|~n|=38 ,
所以,~n=-38,這個就是Java虛擬機的運算結果
(2)n= - 4, 取反 (~-4)
-4補碼:10000000 00000000 00000000 00000100
-4反碼:10000000 00000000 00000000 00000011
-4原碼:11111111 11111111 11111111 11111100
對原碼取反:00000000 00000000 00000000 00000011 (3)
因為是正數,所以補碼等於原碼等於反碼= 3,所以~-4 = 3