訂閱
糾錯
加入自媒體

CPU 中的加法器,為什么可以連同符號位一起運算?

2021-04-08 09:29
道哥分享
關注

4. 補碼的計算

我們先看一下這個問題:假設現(xiàn)在時間是 1 點整,但是你的手表進水了,它顯示的是 3 點整,現(xiàn)在你怎么把時間調整到 1 點的位置?

方法1:把時針逆時針撥動 2 個小時(3 - 2 = 1);

方法2:把時針順時針撥動 9 個小時到 12 點,然后再撥動 1 個小時(3 + 10 = 1);

對于時鐘表盤來說,每 12 個小時為一圈,可以認為:-2 == 10,-1 = 11, -3 = 9,同樣的:-2 == 10, -2 == 22, -2 == 34,...

可以看到規(guī)律是:-2、10、22、34 這些數(shù)字對 12 取模都得到同一個數(shù)(取正數(shù)),在數(shù)學上,兩個整數(shù)除以“同一個整數(shù)”,若得相同余數(shù),則這兩個整數(shù)同余。

表盤中的 12 就是這個“同一個整數(shù)”,可以看到這是一個可“溢出”的系統(tǒng),-2、10、22、34 這幾個數(shù)在表盤上表示的是一樣的數(shù),所以說這幾個整數(shù)同余。

也就是說:在計算的時候,可以用 10、22、34 這幾個數(shù)字來替換 -2,替換之后的計算結果是相同的。

那么對于一個 8 位 的二進制數(shù)來說,最多只有 8 位,在計算過程中,如果最高位產(chǎn)生了進位,就會被丟棄,所以它也是一個可“溢出”的系統(tǒng)。那么這里的“同一個整數(shù)”是多少呢?

從前面的內(nèi)容中可以看到,使用補碼表示的 8 位二進制數(shù)表示的范圍是 -128 ~ 127,一共是 256 個數(shù),所以如果對 256 取模,得到相同的余數(shù),那么這些數(shù)就是同余數(shù)。

例如:-2 和 254 對 256 取模,得到相同的余數(shù),因此它倆就是同余數(shù),那么在計算的時候,就可以用 254 來代替 -2。

那么我們通過計算 3 + (-2) 來驗證一下。

(1) 利用同余數(shù)來計算

3 + (-2) == 3 + 254 = 257

257 超過了最大的表示范圍,所以溢出,結果就是 257 對 256 取模,結果為 1。

(2) 直接用補碼來計算

3 的補碼是 0000_0011,-2 的補碼是 1111_1110,在計算的時候,把符號位也參與運算:

結果也是 1,也就是說:

在二進制計算中,使用補碼來計算,“天然”就滿足了“同余定理”。

細心的讀者可能已經(jīng)發(fā)現(xiàn)了:-2 的二進制補碼表示,與 254 的二進制自然表示,它們的形式是一樣的!

這種“天然”性,是巧合?還是計算機前輩的設計結果?!

五、總結

這篇文章,我們探討了計算機系統(tǒng)的軟件基石:二進制系統(tǒng),主要的目的是幫助你理解二進制的表示、計算方式。

希望你看完之后能夠豁然開朗!如果對您的理解有幫助的話,請轉發(fā)給身邊的技術小伙伴,共同成長!

謝謝!


<上一頁  1  2  3  4  
聲明: 本文由入駐維科號的作者撰寫,觀點僅代表作者本人,不代表OFweek立場。如有侵權或其他問題,請聯(lián)系舉報。

發(fā)表評論

0條評論,0人參與

請輸入評論內(nèi)容...

請輸入評論/評論長度6~500個字

您提交的評論過于頻繁,請輸入驗證碼繼續(xù)

暫無評論

暫無評論

人工智能 獵頭職位 更多
掃碼關注公眾號
OFweek人工智能網(wǎng)
獲取更多精彩內(nèi)容
文章糾錯
x
*文字標題:
*糾錯內(nèi)容:
聯(lián)系郵箱:
*驗 證 碼:

粵公網(wǎng)安備 44030502002758號