一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

完善資料讓更多小伙伴認(rèn)識你,還能領(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ǔ)碼可以簡化計(jì)算機(jī)硬件電路設(shè)計(jì)的復(fù)雜度。

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

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

簡化硬件電路的代價(jià)就是有符號數(shù)在存儲和讀取時(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ù)的反碼不一樣。

對于正數(shù),它的反碼就是其原碼(原碼和反碼相同);負(fù)數(shù)的反碼是將原碼中除符號位以外的所有位(數(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è)特殊的編碼會出現(xiàn):

[0_0000000]=+0 (反碼)

[1_1111111]=-0 (反碼)

+0 和 -0 代表的都是 0。這樣一來,“0” 這個(gè)數(shù)字在計(jì)算機(jī)中的編碼就不是唯一的了。對于計(jì)算機(jī)來說,這是絕對不行的,因?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ù)整體向后“挪動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)換為原碼也很簡單:先減去 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ì)硬件簡單!”

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

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

有了補(bǔ)碼,對加減運(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)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 電路
    +關(guān)注

    關(guān)注

    173

    文章

    6027

    瀏覽量

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

    關(guān)注

    19

    文章

    7663

    瀏覽量

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

    關(guān)注

    77

    文章

    10020

    瀏覽量

    141751

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

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    云端超級計(jì)算機(jī)使用教程

    云端超級計(jì)算機(jī)是一種基于云計(jì)算的高性能計(jì)算服務(wù),它將大量計(jì)算資源和存儲資源集中在一起,通過網(wǎng)絡(luò)向用戶提供按需的計(jì)算服務(wù)。下面,AI部落小編為
    的頭像 發(fā)表于 12-17 10:19 ?553次閱讀

    工業(yè)中使用哪種計(jì)算機(jī)

    在工業(yè)環(huán)境中,工控機(jī)被廣泛使用。這些計(jì)算機(jī)的設(shè)計(jì)可承受極端溫度、灰塵和振動等惡劣條件。它們比標(biāo)準(zhǔn)消費(fèi)類計(jì)算機(jī)更耐用、更可靠。工業(yè)計(jì)算機(jī)可控制機(jī)器、監(jiān)控流程并實(shí)時(shí)收集數(shù)據(jù)。其堅(jiān)固的結(jié)構(gòu)和專業(yè)功能
    的頭像 發(fā)表于 11-29 14:07 ?716次閱讀
    工業(yè)中使用哪種<b class='flag-5'>計(jì)算機(jī)</b>?

    量子計(jì)算機(jī)與普通計(jì)算機(jī)工作原理的區(qū)別

    ? 本文介紹了量子計(jì)算機(jī)與普通計(jì)算機(jī)工作原理的區(qū)別。 量子計(jì)算是一個(gè)新興的研究領(lǐng)域,科學(xué)家們利用量子力學(xué),制造出具有革命性能力的計(jì)算機(jī)。雖然現(xiàn)在的量子
    的頭像 發(fā)表于 11-24 11:00 ?1506次閱讀
    量子<b class='flag-5'>計(jì)算機(jī)</b>與普通<b class='flag-5'>計(jì)算機(jī)</b>工作原理的區(qū)別

    工業(yè)計(jì)算機(jī)類型介紹

    工業(yè)領(lǐng)域沒有計(jì)算機(jī)的世界就像沒有管弦樂隊(duì)的交響樂,缺乏實(shí)現(xiàn)最佳性能所需的和諧和精確度。計(jì)算機(jī)徹底改變了工業(yè)的運(yùn)作方式,將效率、準(zhǔn)確性和創(chuàng)新推向了新的高度。事實(shí)上,根據(jù)最近在印度進(jìn)行的一項(xiàng)研究
    的頭像 發(fā)表于 11-04 15:56 ?673次閱讀
    工業(yè)<b class='flag-5'>計(jì)算機(jī)</b>類型介紹

    ROM對計(jì)算機(jī)性能的影響

    只讀存儲器(ROM)是計(jì)算機(jī)硬件中的一個(gè)重要組成部分,它負(fù)責(zé)存儲計(jì)算機(jī)啟動時(shí)必需的固件和基本輸入輸出系統(tǒng)(BIOS)。ROM的性能和質(zhì)量對計(jì)算機(jī)的整體性能有著深遠(yuǎn)的影響。 ROM的基本概念 ROM
    的頭像 發(fā)表于 11-04 10:31 ?1224次閱讀

    計(jì)算機(jī)接口位于什么之間

    計(jì)算機(jī)接口是計(jì)算機(jī)硬件和軟件之間、計(jì)算機(jī)與外部設(shè)備之間以及計(jì)算機(jī)各部件之間傳輸數(shù)據(jù)、控制信息和狀態(tài)信息的硬件設(shè)備和軟件程序。它在計(jì)算機(jī)系統(tǒng)中
    的頭像 發(fā)表于 10-14 14:02 ?1325次閱讀

    計(jì)算機(jī)存儲系統(tǒng)的工作原理和功能

    計(jì)算機(jī)存儲系統(tǒng)作為計(jì)算機(jī)系統(tǒng)中至關(guān)重要的組成部分,其原理和功能對于理解計(jì)算機(jī)的運(yùn)行機(jī)制具有關(guān)鍵意義。以下將詳細(xì)闡述計(jì)算機(jī)存儲系統(tǒng)的原理和功能。
    的頭像 發(fā)表于 09-26 16:42 ?2965次閱讀

    計(jì)算機(jī)存儲系統(tǒng)的構(gòu)成

    計(jì)算機(jī)存儲系統(tǒng)是計(jì)算機(jī)中用于存放程序和數(shù)據(jù)的設(shè)備或部件的集合,它構(gòu)成了計(jì)算機(jī)信息處理的基礎(chǔ)。一個(gè)完整的計(jì)算機(jī)存儲系統(tǒng)通常包括多個(gè)層次的存儲器,從高速緩存(Cache)到主存儲器(Mai
    的頭像 發(fā)表于 09-26 15:25 ?2547次閱讀

    二進(jìn)制補(bǔ)碼及與原碼的互相轉(zhuǎn)換方法

    大沙把一些基礎(chǔ)的知識說清楚,本文介紹二進(jìn)制補(bǔ)碼及與原碼的轉(zhuǎn)換方法。 先說原碼,原碼?是一種計(jì)算機(jī)中對數(shù)字的二進(jìn)制定點(diǎn)表示方法。在原碼表示法中,數(shù)值前面增加了一位符號位,最高位為符號位,0表示正數(shù),1
    的頭像 發(fā)表于 09-19 22:25 ?1497次閱讀

    計(jì)算機(jī)系統(tǒng)的硬件組成和主要部件

    計(jì)算機(jī)系統(tǒng)的硬件組成是計(jì)算機(jī)運(yùn)行的基礎(chǔ),它包含了多個(gè)關(guān)鍵部件,這些部件相互協(xié)作,共同實(shí)現(xiàn)計(jì)算機(jī)的各種功能。
    的頭像 發(fā)表于 09-10 11:41 ?6932次閱讀

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

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

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

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

    晶體管計(jì)算機(jī)的誕生和特點(diǎn)

    晶體管計(jì)算機(jī)的誕生標(biāo)志著計(jì)算機(jī)技術(shù)的一個(gè)重要里程碑,它不僅推動了計(jì)算機(jī)硬件的革新,還促進(jìn)了計(jì)算機(jī)軟件技術(shù)的發(fā)展。以下是對晶體管計(jì)算機(jī)誕生及其
    的頭像 發(fā)表于 08-23 15:06 ?4253次閱讀

    計(jì)算機(jī)系統(tǒng)的組成和功能

    計(jì)算機(jī)系統(tǒng)是一個(gè)復(fù)雜而龐大的概念,它涵蓋了計(jì)算機(jī)硬件、軟件以及它們之間相互作用的所有元素。為了全面而深入地探討計(jì)算機(jī)系統(tǒng),本文將從定義、組成、功能、發(fā)展歷程以及未來趨勢等方面進(jìn)行詳細(xì)闡述。
    的頭像 發(fā)表于 07-24 17:41 ?2414次閱讀

    DRAM在計(jì)算機(jī)中的應(yīng)用

    DRAM(Dynamic Random Access Memory,動態(tài)隨機(jī)存取存儲器)在計(jì)算機(jī)系統(tǒng)中扮演著至關(guān)重要的角色。它是一種半導(dǎo)體存儲器,用于存儲和快速訪問數(shù)據(jù),是計(jì)算機(jī)主內(nèi)存的主要組成部分。以下是對DRAM在計(jì)算機(jī)中的
    的頭像 發(fā)表于 07-24 17:04 ?3021次閱讀