原碼 反碼和補碼

2021-09-12 02:39:22 字數 537 閱讀 4330

// what results from the following code fragment?

int i = 5;

int j = 10;

system.out.println(i + ~j);

計算機中的數都是以原碼儲存。

在計算機中,int i = 5,編碼為0000 0000 0000 0101;

int j = 10,編碼為0000 0000 0000 1010;

~j,編碼為1111 1111 1111 0101;

計算機中的1111 1111 1111 0101(補碼)對應的原碼為1000 0000 0000 1011,即十進位制-11,

所以最終的列印結果為-6.

原碼:符號位加上真值的絕對值,即用第乙個二進位制位表示符號(正數為0,負數為1),其餘位表示值。

反碼:正數的反碼 = 其原碼;

負數的反碼 = 符號位不變,其餘各位取反。

補碼:正數的補碼= 其原碼;

負數的補碼 = 符號位不變,其反碼+1。

原碼 反碼和補碼

數值有正負之分 計算機就用乙個數的最高位存放符號 0為正 1為負 這就是機器數的原碼了 假設機器能處理的位數為 8.即字長為 1byte,原碼能表示數值的範圍為 127 0 0 127 共256個.有了數值的表示方法就可以對數進行算術運算 但是很快就發現用帶符號位的原碼進行乘除運算時結果正確 而在加...

原碼 反碼 和 補碼。

這裡只講下自己對反碼的理解。大家都知道使用反碼表示負數有兩個優點,1.可以使得減法可以和加法一樣。2.符號位也參與了運算。那這是為什麼呢?下面可以進行一些簡單的數學推導 根據反碼定義,對於負數,反碼是除符號為以外取反 1。例如,4 變換步驟如下。a 4 0 000 0100 b 取反 0 111 1...

原碼 補碼和反碼

1 原碼表示法 原碼表示法是機器數的一種簡單的表示法。其符號位用0表示正號,用 表示負號,數值一般用二進位制形式表示。設有一數為x,則原碼表示可記作 x 原。例如,x1 1010110 x2 一1001010 其原碼記作 x1 原 1010110 原 01010110 x2 原 1001010 原 ...