最近在備戰軟考,複習到計算機組成原理的時候,看到書中關於原碼、反碼、補碼和移碼的定義如下(n是機器字長):
原碼:
反碼:
補碼:
移碼:
看完這些定義以後,我的腦袋瞬間膨脹到原來的二倍!這樣**的公式不管你記不記得住,反正我是記不住!還好以前對它們有所了解,否則看到這一堆公式恐怕我早就放棄參加軟考的念頭嘍。
其實沒必要弄得這麼麻煩,它們完全可以用一兩句話就描述的很清楚。
原碼:
如果機器字長為n,那麼乙個數的原碼就是用乙個n位的二進位制數,其中最高位為符號位:正數為1,負數為0。剩下的n-1位表示概數的絕對值。
例如: x=+101011 , [x]原= 00101011 x=-101011 , [x]原= 10101011
位數不夠的用0補全。
ps:正數的原、反、補碼都一樣。
反碼:
知道了什麼是原碼,那反碼就更是張飛吃豆芽——小菜一碟了。知道了原碼,那麼你只需要具備區分0跟1的能力就可以輕鬆求出反碼,為什麼呢?因為反碼就是在原碼的基礎上,符號位不變其他位按位取反(就是0變1,1變0)就可以了。
例如:x=-101011 , [x]原= 10101011 ,[x]反=11010100
補碼:
補碼也非常的簡單就是在反碼的基礎上按照正常的加法運算加1。
例如:x=-101011 , [x]原= 10101011 ,[x]反=11010100,[x]補=11010101
移碼:
移碼最簡單了,不管正負數,只要將其補碼的符號位取反即可。
例如:x=-101011 , [x]原= 10101011 ,[x]反=11010100,[x]補=11010101,[x]移=01010101
以上內容只適合初學者參考,高手勿噴,有說的不對的地方歡迎指出,感激不盡!
**:
軟考 原碼 反碼 補碼 移碼
在計算機中,資料編碼方式可以有多種,最為常見的有原碼 反碼 補碼 移碼。在進行原碼,反碼,補碼,移碼之間的轉換的時候首先要將他們轉換為二進位制,在下面的講解中以17為例來進行講解。將17轉換為八位數的二進位制為00010001。在原碼中,將最高位用作符號位 0表示正數,1表示負數 其餘各位代表數值本...
軟考筆記(1) 原碼 反碼 補碼 移碼轉換
各種數值在計算機中表示的形式成為機器數,採用二進位制計數制,數的符號用0 正數 和1 負數 表示,小數點隱含表示 不佔位置 機器數分為無符號數和帶符號數,帶符號數又分為純整數和純小數。純整數 對無符號數,若約定小數點的位置在機器數的最低位之後,則為純整數,如123。純小數 對無符號數,若約定小數點的...
軟考必備2 原碼 反碼 補碼和移碼
1 原碼 反碼 補碼和移碼 原碼例子如下 在原碼表示法中,最高位是符號位,0表示正號,1表示負號,其餘的n 1 位表示數值的絕對值。反碼例子如下 正數的反碼與原碼相同,負數的反碼則是其絕對值按位求反。其餘規則和原碼的一樣。補碼例子如下 正數的補碼與其原碼和反碼相同,負數的補碼則等於其反碼的末尾加1,...