0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

計(jì)算機(jī)為什么要使用補(bǔ)碼

strongerHuang ? 來源:C語言與CPP編程 ? 作者:自成一派123 ? 2021-09-12 16:06 ? 次閱讀

人類在制造出晶體管后,利用晶體管制造出了與非門,然后又利用與非門制造出了加法器。加法器解決了加法運(yùn)算問題。只有加法器是不夠的,還需要解決減法的計(jì)算問題,但是與加法器相比,設(shè)計(jì)減法器硬件更為復(fù)雜,增加了計(jì)算的時(shí)間,能不能用加法器實(shí)現(xiàn)減法器的功能?這個(gè)實(shí)現(xiàn)的過程就用到了補(bǔ)碼。

計(jì)算機(jī)為什么使用補(bǔ)碼?采用補(bǔ)碼可以簡(jiǎn)化計(jì)算機(jī)硬件電路設(shè)計(jì)的復(fù)雜度。

對(duì)于有符號(hào)數(shù),內(nèi)存要區(qū)分符號(hào)位和數(shù)值位,要是能把符號(hào)位和數(shù)值位等同起來,讓它們一起參與運(yùn)算,不再加以區(qū)分,只用加法器就可以同時(shí)實(shí)現(xiàn)加法和減法運(yùn)算,這樣硬件電路就變得簡(jiǎn)單了。

8 - 3 等價(jià)于 8 + (-3),12 - (-9) 等價(jià)于 10 + 9。

簡(jiǎn)化硬件電路的代價(jià)就是有符號(hào)數(shù)在存儲(chǔ)和讀取時(shí)都要進(jìn)行轉(zhuǎn)化。這個(gè)轉(zhuǎn)換過程就涉及到我們熟悉的原碼、反碼、補(bǔ)碼。

原碼將一個(gè)整數(shù)轉(zhuǎn)換成二進(jìn)制形式,就是其原碼。例如short a = 5;,a 的原碼就是0000 0000 0000 0101;更改 a 的值a = -19;,此時(shí) a 的原碼就是1000 0000 0001 0011。

通俗的理解,原碼就是一個(gè)整數(shù)本來的二進(jìn)制形式。

反碼正數(shù)與負(fù)數(shù)的反碼不一樣。

對(duì)于正數(shù),它的反碼就是其原碼(原碼和反碼相同);負(fù)數(shù)的反碼是將原碼中除符號(hào)位以外的所有位(數(shù)值位)取反,也就是 0 變成 1,1 變成 0。例如 short a = 5;,a 的原碼和反碼都是 0000 0000 0000 0101;更改 a 的值 a = -19;,此時(shí) a 的反碼是 1111 1111 1110 1100。

為什么需要反碼,反碼的作用就相當(dāng)于數(shù)學(xué)中的負(fù)數(shù),有了負(fù)數(shù),才可以實(shí)現(xiàn)減法與加法運(yùn)算統(tǒng)一成加法運(yùn)算。

補(bǔ)碼有了反碼為什么還需要補(bǔ)碼

因?yàn)?“0” 這個(gè)特殊數(shù)字的存在。

將減法運(yùn)算按加法運(yùn)算處理,負(fù)數(shù)需要用反碼表示,那么用 8 位二進(jìn)制反碼表示的正數(shù)范圍:+0 —— +127;負(fù)數(shù)范圍:-127 —— -0。但是,其中有兩個(gè)特殊的編碼會(huì)出現(xiàn):

[0_0000000]=+0 (反碼)

[1_1111111]=-0 (反碼)

+0 和 -0 代表的都是 0。這樣一來,“0” 這個(gè)數(shù)字在計(jì)算機(jī)中的編碼就不是唯一的了。對(duì)于計(jì)算機(jī)來說,這是絕對(duì)不行的,因?yàn)槿魏螖?shù)字都只能有 1 個(gè)編碼。

我們知道 0 既不是正數(shù)也不是負(fù)數(shù),為了解決這個(gè)編碼不唯一的問題,把 0 當(dāng)成正數(shù),也即 +0,這樣 0 的編碼就變成:0_0000000。那 8 位二進(jìn)制表示的正數(shù)范圍仍然是:+0 —— +127。負(fù)數(shù)整體向后“挪動(dòng)1位”,反碼 +1,{1_1111111}編碼就不再表示 -0,而變成了 -1。順著推,最小的編碼{1_0000000}就是 -128,8 位二進(jìn)制表示的負(fù)數(shù)范圍從:-127 —— -0 變成:-128 —— -1,就能成功解決問題。

這種操作好像是在反碼上打了“補(bǔ)丁”,進(jìn)行了一下修正,所以稱之為補(bǔ)碼,補(bǔ)碼定義如下:

1.正數(shù)的補(bǔ)碼保持原碼不變:5 = 0_000 0000 0000 0101

2.負(fù)數(shù)先求反碼,然后再加1:-19 = 1_111 1111 1110 1100 + 1 = 1_111 1111 1110 1101

5 - 19 的計(jì)算過程:

0_000 0000 0000 0101 + 1_111 1111 1110 1101 = 1_111 1111 1111 0010;

將補(bǔ)碼轉(zhuǎn)換為原碼也很簡(jiǎn)單:先減去 1,再將數(shù)值位取反即可。

1_111 1111 1111 0010 逆向轉(zhuǎn)換原碼是:1000 0000 0000 1110 = -14

采用補(bǔ)碼成功解決了數(shù)字 0 在計(jì)算機(jī)中非唯一編碼的問題,也實(shí)現(xiàn)了減法變加法。

總結(jié)補(bǔ)碼是為了解決負(fù)數(shù)在計(jì)算機(jī)中的表示問題,最終是為了解決計(jì)算機(jī)的減法運(yùn)算問題。計(jì)算機(jī)中采用了補(bǔ)碼的根本原因是,“設(shè)計(jì)硬件簡(jiǎn)單!”

不浪費(fèi)編碼個(gè)數(shù);

省去計(jì)算機(jī)判斷符號(hào)位或者說判斷+/-運(yùn)算的麻煩。

有了補(bǔ)碼,對(duì)加減運(yùn)算,硬件上,只有一種加法器就行了;

有了加減運(yùn)算,用程序就可以實(shí)現(xiàn)乘除運(yùn)算,不用額外增加硬件;

有了加減乘除運(yùn)算,用程序就可以實(shí)現(xiàn)“所有”算術(shù)運(yùn)算了,不用額外增加硬件。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 電路
    +關(guān)注

    關(guān)注

    171

    文章

    5747

    瀏覽量

    171207
  • 計(jì)算機(jī)
    +關(guān)注

    關(guān)注

    19

    文章

    7174

    瀏覽量

    87159
  • 晶體管
    +關(guān)注

    關(guān)注

    77

    文章

    9502

    瀏覽量

    136943

原文標(biāo)題:計(jì)算機(jī)為什么要用補(bǔ)碼?

文章出處:【微信號(hào):strongerHuang,微信公眾號(hào):strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    簡(jiǎn)述計(jì)算機(jī)總線的分類

    計(jì)算機(jī)總線作為計(jì)算機(jī)系統(tǒng)中連接各個(gè)功能部件的公共通信干線,其結(jié)構(gòu)和分類對(duì)于理解計(jì)算機(jī)硬件系統(tǒng)的工作原理至關(guān)重要。以下是對(duì)計(jì)算機(jī)總線結(jié)構(gòu)和分類的詳細(xì)闡述,內(nèi)容將涵蓋總線的基本概念、內(nèi)部結(jié)
    的頭像 發(fā)表于 08-26 16:23 ?204次閱讀

    晶體管計(jì)算機(jī)和電子管計(jì)算機(jī)有什么區(qū)別

    晶體管計(jì)算機(jī)和電子管計(jì)算機(jī)作為計(jì)算機(jī)發(fā)展史上的兩個(gè)重要階段,它們?cè)诙鄠€(gè)方面存在顯著的區(qū)別。以下是對(duì)這兩類計(jì)算機(jī)在硬件、性能、應(yīng)用以及技術(shù)發(fā)展等方面區(qū)別的詳細(xì)闡述。
    的頭像 發(fā)表于 08-23 15:28 ?451次閱讀

    工業(yè)控制計(jì)算機(jī)的特點(diǎn) 工業(yè)控制計(jì)算機(jī)的應(yīng)用領(lǐng)域

    工業(yè)控制計(jì)算機(jī)是一種專門為工業(yè)自動(dòng)化和控制系統(tǒng)設(shè)計(jì)的計(jì)算機(jī)。它具有高度的可靠性、穩(wěn)定性和實(shí)時(shí)性,能夠滿足工業(yè)生產(chǎn)過程中對(duì)控制精度和響應(yīng)速度的嚴(yán)格要求。 工業(yè)控制計(jì)算機(jī)的特點(diǎn) 高可靠性 :工業(yè)控制
    的頭像 發(fā)表于 06-16 11:30 ?985次閱讀

    工業(yè)控制計(jì)算機(jī)與普通個(gè)人計(jì)算機(jī)相比有何區(qū)別?

    引言 隨著科技的不斷發(fā)展,計(jì)算機(jī)在各個(gè)領(lǐng)域的應(yīng)用越來越廣泛。在眾多計(jì)算機(jī)類型中,工業(yè)控制計(jì)算機(jī)和普通個(gè)人計(jì)算機(jī)是兩種常見的計(jì)算機(jī)。盡管它們?cè)?/div>
    的頭像 發(fā)表于 06-11 10:45 ?543次閱讀

    工業(yè)計(jì)算機(jī)與普通計(jì)算機(jī)的區(qū)別

    在信息化和自動(dòng)化日益發(fā)展的今天,計(jì)算機(jī)已經(jīng)成為了我們?nèi)粘I詈凸ぷ髦胁豢苫蛉钡墓ぞ?。然而,?b class='flag-5'>計(jì)算機(jī)領(lǐng)域中,工業(yè)計(jì)算機(jī)和普通計(jì)算機(jī)雖然都具備基本的計(jì)算
    的頭像 發(fā)表于 06-06 16:45 ?678次閱讀

    【量子計(jì)算機(jī)重構(gòu)未來 | 閱讀體驗(yàn)】+量子計(jì)算機(jī)的原理究竟是什么以及有哪些應(yīng)用

    本書內(nèi)容從目錄可以看出本書主要是兩部分內(nèi)容,一部分介紹量子計(jì)算機(jī)原理,一部分介紹其應(yīng)用。 其實(shí)個(gè)人也是抱著對(duì)這兩個(gè)問題的興趣來看的。 究竟什么是量子計(jì)算機(jī)相信很多讀者都是抱著這個(gè)疑問
    發(fā)表于 03-11 12:50

    【量子計(jì)算機(jī)重構(gòu)未來 | 閱讀體驗(yàn)】+ 初識(shí)量子計(jì)算機(jī)

    欣喜收到《量子計(jì)算機(jī)——重構(gòu)未來》一書,感謝電子發(fā)燒友論壇提供了一個(gè)讓我了解量子計(jì)算機(jī)的機(jī)會(huì)! 自己對(duì)電子計(jì)算機(jī)有點(diǎn)了解,但對(duì)量子計(jì)算機(jī)真是一無所知,只是聽說過量子糾纏、超快的運(yùn)算速
    發(fā)表于 03-05 17:37

    量子計(jì)算機(jī)的未來

    了解量子計(jì)算機(jī)對(duì)于工業(yè)生產(chǎn)和產(chǎn)品研發(fā)的使用
    發(fā)表于 02-01 15:30

    微機(jī)原理和計(jì)算機(jī)組成原理的區(qū)別

    微機(jī)原理和計(jì)算機(jī)組成原理是計(jì)算機(jī)科學(xué)中兩個(gè)重要的主題,它們雖然有一定的關(guān)聯(lián),但也存在一些區(qū)別。本文將詳細(xì)闡述微機(jī)原理和計(jì)算機(jī)組成原理的區(qū)別,并從不同的角度對(duì)它們進(jìn)行分析比較。 首先,我們從定義的角度
    的頭像 發(fā)表于 01-14 14:56 ?2547次閱讀

    計(jì)算機(jī)原碼、反碼、補(bǔ)碼的概念

    計(jì)算機(jī)內(nèi)部數(shù)值是以補(bǔ)碼的方式進(jìn)行存儲(chǔ)的,采用補(bǔ)碼進(jìn)行數(shù)據(jù)存儲(chǔ)當(dāng)然有其優(yōu)點(diǎn),下面會(huì)一一介紹相關(guān)內(nèi)容,讓各位徹底弄懂原碼、反碼、補(bǔ)碼的概念以及為什么采用
    的頭像 發(fā)表于 01-09 12:25 ?3086次閱讀
    <b class='flag-5'>計(jì)算機(jī)</b>原碼、反碼、<b class='flag-5'>補(bǔ)碼</b>的概念

    量子計(jì)算機(jī)的作用有哪些

    量子計(jì)算機(jī)是一種基于量子力學(xué)原理的新型計(jì)算機(jī),它利用量子比特(qubit)進(jìn)行信息處理,具有傳統(tǒng)計(jì)算機(jī)無法比擬的計(jì)算能力和潛力。量子計(jì)算機(jī)
    的頭像 發(fā)表于 12-30 14:32 ?1488次閱讀

    工業(yè)計(jì)算機(jī)與商用計(jì)算機(jī)的區(qū)別

    工業(yè)計(jì)算機(jī)與商用計(jì)算機(jī)的區(qū)別? 工業(yè)計(jì)算機(jī)和商用計(jì)算機(jī)是兩種應(yīng)用于不同領(lǐng)域的計(jì)算機(jī)系統(tǒng)。雖然它們?cè)诩夹g(shù)方面存在一些共性,但在功能、設(shè)計(jì)、可靠
    的頭像 發(fā)表于 12-27 10:50 ?495次閱讀

    什么是后量子密碼學(xué)?量子計(jì)算機(jī)vs經(jīng)典計(jì)算機(jī)

    后量子密碼學(xué)(Post-Quantum Cryptography,PQC)是在經(jīng)典計(jì)算機(jī)上定義和執(zhí)行算法,研究量子計(jì)算機(jī)和經(jīng)典計(jì)算機(jī)都無法破解的新密碼系統(tǒng)。后量子密碼學(xué)的提出是為了抵抗量子計(jì)算
    的頭像 發(fā)表于 12-19 11:42 ?1341次閱讀

    單板計(jì)算機(jī)是什么?它與其他計(jì)算機(jī)有何不同?

    單板計(jì)算機(jī)是什么?它與其他計(jì)算機(jī)有何不同? 單板計(jì)算機(jī)(Single Board Computer,SBC)是一種集成了所有計(jì)算機(jī)部件的完整計(jì)算機(jī)
    的頭像 發(fā)表于 12-15 09:58 ?1047次閱讀

    什么是計(jì)算機(jī)視覺?計(jì)算機(jī)視覺的三種方法

    計(jì)算機(jī)視覺是指通過為計(jì)算機(jī)賦予人類視覺這一技術(shù)目標(biāo),從而賦能裝配線檢查到駕駛輔助和機(jī)器人等應(yīng)用。計(jì)算機(jī)缺乏像人類一樣憑直覺產(chǎn)生視覺和畫面的能力,所以我們必須給予計(jì)算機(jī)一些算法,以便處理
    的頭像 發(fā)表于 11-16 16:38 ?4165次閱讀
    什么是<b class='flag-5'>計(jì)算機(jī)</b>視覺?<b class='flag-5'>計(jì)算機(jī)</b>視覺的三種方法