chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

計(jì)算機(jī)中CPU是如何識(shí)數(shù)的

strongerHuang ? 來(lái)源:Python數(shù)據(jù)科學(xué) ? 作者:東哥起飛 ? 2021-10-08 16:38 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

先來(lái)看一個(gè)簡(jiǎn)單的問(wèn)題:小孩子都知道數(shù)數(shù):1,2,3,4,5,6,7,8,9,10,可為什么要這樣數(shù)呢?為什么不是1,2,3,4,5,6,10呢?

一種比較流行的解釋是因?yàn)槿祟愑?0個(gè)手指,所以人類的數(shù)字系統(tǒng)就是10進(jìn)制的,如果這個(gè)解釋成立,那么變色龍的數(shù)字系統(tǒng)應(yīng)該是4進(jìn)制,而計(jì)算機(jī)的手是單指,所以是2進(jìn)制。

哈哈,開(kāi)個(gè)玩笑,其實(shí)計(jì)算機(jī)在最最最最底層就是一個(gè)個(gè)開(kāi)關(guān),因此計(jì)算機(jī)系統(tǒng)是2進(jìn)制,關(guān)于CPU的構(gòu)造你可以參考《你管這破玩意叫 CPU?》:

數(shù)字 0 與正整數(shù)

0這個(gè)數(shù)字其實(shí)有非常重要的意義,可能大家都沒(méi)想過(guò)這個(gè)問(wèn)題,沒(méi)關(guān)系,我們來(lái)看兩個(gè)不同的數(shù)字系統(tǒng):阿拉伯?dāng)?shù)字和羅馬數(shù)字。

注意,羅馬數(shù)字中沒(méi)有 “0” 這個(gè)概念,你可能會(huì)想,這有什么大不了的嗎?讓我們來(lái)看一個(gè)例子,數(shù)字205,分別在兩種系統(tǒng)的表示。羅馬:CCV阿拉伯:2050的出現(xiàn)可以讓阿拉伯?dāng)?shù)字系統(tǒng)中205這樣寫(xiě)。

可以看到,在阿拉伯系統(tǒng)中數(shù)值和數(shù)字所在的位置有直接關(guān)系,這就是進(jìn)位制,而在羅馬數(shù)字系統(tǒng)則沒(méi)有進(jìn)位制,這使得羅馬數(shù)字在表示大數(shù)值時(shí)非常困難。計(jì)算機(jī)系統(tǒng)中的二進(jìn)制同樣是進(jìn)位制,數(shù)字5用二進(jìn)制表示就是101。

使用 k 個(gè)bit,那么可以表示 2^k 個(gè)整數(shù),范圍從 0 到 2^k - 1,假設(shè) k 有 8 位,那么表示范圍就是 0 到 255,當(dāng)然這里說(shuō)的是無(wú)符號(hào)正整數(shù)?,F(xiàn)在我們可以表示正整數(shù)了,但真正有用的計(jì)算不可避免會(huì)涉及到負(fù)數(shù),也就是帶符號(hào)整數(shù),而這也是真正有趣的地方。

有符號(hào)整數(shù)正整數(shù)的表示非常簡(jiǎn)單,給定 k 個(gè)bit,那么我們可以表示 2^k 個(gè)數(shù),假設(shè)k為4,那么我們可以表示16個(gè)數(shù)字。如果要考慮有符號(hào)整數(shù)呢?你可能會(huì)想這還不簡(jiǎn)單,一半一半嘛!其中一半用來(lái)表示正數(shù),另一半用來(lái)表示負(fù)數(shù)!假設(shè)有4個(gè)比特位,如果用來(lái)表示無(wú)符號(hào)正數(shù),就是0 ~ 15,而如果要表示有符號(hào)整數(shù),那么其中一半給到+1 ~ +7,另一半給到-1 ~ -7,一切看最左邊的 bit 是 0,如果最左邊的 bit 位是 0 則表示正數(shù),否則表示負(fù)數(shù)。

現(xiàn)在我們已經(jīng)知道正負(fù)數(shù)是通過(guò)什么來(lái)決定的了,接下來(lái)的問(wèn)題就是負(fù)數(shù)該怎么表示呢?也就是說(shuō)對(duì)于比如-2,現(xiàn)在我們只知道其最左邊的 bit 位是1,那么右邊的這些 bit 到底該是多少呢?關(guān)于這一問(wèn)題就三種設(shè)計(jì)方法。

方法1:正數(shù)加上負(fù)號(hào)即對(duì)應(yīng)負(fù)數(shù)第一種設(shè)計(jì)方法很簡(jiǎn)單,既然0010表示+2,那么如果最左邊的bit位替換成1就表示對(duì)應(yīng)的負(fù)數(shù),即1010表示-2,這種設(shè)計(jì)方法簡(jiǎn)單直接,這是最符合人類的思維的設(shè)計(jì)(不一定最好)。如果這樣設(shè)計(jì)的話

你給這種非常符合人類思維的數(shù)字表示方法起了個(gè)名字,原碼。這種設(shè)計(jì)下會(huì)有一個(gè)奇怪的表示:0000表示0這沒(méi)什么問(wèn)題,1000會(huì)表示 -0,這會(huì)導(dǎo)致出現(xiàn)-0這樣的數(shù)字,其實(shí) 0 和 -0 不應(yīng)該有什么區(qū)別。身為設(shè)計(jì)天才的你顯然不滿足于此,是不是還有其它設(shè)計(jì)方法?

方法2:翻轉(zhuǎn)你覺(jué)得第一種表示方法也就是原碼太原始,可以說(shuō)基本上沒(méi)什么設(shè)計(jì),你突發(fā)奇想,既然0010表示+2,那么將其全部翻轉(zhuǎn),即1101來(lái)表示-2好了,你給這種表示方法也起了名字,反碼。在反碼表示法下,也存在-0,0000表示0,全部翻轉(zhuǎn)也就是1111來(lái)表示-0,可以看到這和原碼表示方法差別沒(méi)那么大。

設(shè)計(jì)計(jì)算機(jī)很容易嗎?到這里有的同學(xué)可能會(huì)想,計(jì)算機(jī)設(shè)計(jì)者其實(shí)怎么來(lái)表示有符號(hào)數(shù)其實(shí)都是可以的,原碼可以,反碼也可以,都能表示出來(lái),設(shè)計(jì)計(jì)算機(jī)太容易了吧!你猜的沒(méi)錯(cuò),就是這么容易!如果你是計(jì)算機(jī)的創(chuàng)造者,怎么設(shè)計(jì)都可以!最初的計(jì)算機(jī)設(shè)計(jì)者真的可以有很多表示數(shù)字的方法,采用反碼表示數(shù)字的計(jì)算機(jī)系統(tǒng)在歷史上真的出現(xiàn)過(guò)!??!但這些表示方法不約而同都有一個(gè)問(wèn)題,那就是兩數(shù)相加。

不簡(jiǎn)單的兩數(shù)相加我們以2 + ( -2 )為例。在原碼表示法下,2為0010,-2為1010,那么計(jì)算機(jī)該怎么做2 + ( -2 )加法呢?

可是1100在原碼表示法下是 -4,這與原碼表示法本身是矛盾的。再來(lái)看看反碼,2為0010,-2為1101,兩數(shù)相加:

1111在反碼表示下為-0,雖然-0不夠優(yōu)雅,但好歹和反碼表示法本身沒(méi)有矛盾,這大概就是為什么早期會(huì)有計(jì)算機(jī)采用反碼表示數(shù)字的原因。在《你管這破玩意叫CPU?》一文中我們知道,計(jì)算機(jī)加法是通過(guò)加法器組合電路實(shí)現(xiàn)的,而這里的不管是原碼還是反碼,要想計(jì)算加法都不可避免的要在前面提到的加法器之上額外添加組合電路來(lái)確保有符號(hào)數(shù)相加的正確性,這無(wú)疑會(huì)增加電路設(shè)計(jì)的復(fù)雜度。人是懶惰的也是聰明的,我們就沒(méi)有一種2+-2就是0(0000)的數(shù)字表達(dá)方法嗎?

新的表示方法現(xiàn)在,對(duì)于最左邊的bit位來(lái)說(shuō),0表示正數(shù),1表示負(fù)數(shù)是沒(méi)有什么異議的,這里的關(guān)鍵在于我們需要一種表示方法,可以讓A+(-A) = 0,而且這里0的二進(jìn)制也是0,如果是4個(gè)bit為的話就應(yīng)該是0000。假設(shè)A=2,那么我們重點(diǎn)研究下2+-2 = 0(0000)的表示方法。對(duì)于2來(lái)說(shuō),很簡(jiǎn)單就是0010,對(duì)于-2來(lái)說(shuō),現(xiàn)在我們只能確定最左邊的bit位是1。

顯然 -2 應(yīng)該用1110來(lái)表示,這樣2+-2就真的是0了,由此推斷:

從圖中可以看出這種表示方法下就沒(méi)有-0了。注意看-1和0,分別是1111和0000,當(dāng)我們讓-1(1111)加上1(0001)時(shí),我們確實(shí)得到了0000,不過(guò)還有一個(gè)進(jìn)位,實(shí)際上我們得到的是10000,但我們可以放心的忽略掉該進(jìn)位。這種表示方法最美妙的地方在于《你管這破玩意叫CPU》一文中提到的加法器不用修改就可以直接計(jì)算有符號(hào)數(shù)字的加法。你可以自己試驗(yàn)幾個(gè)數(shù)字相加就能發(fā)下這種表示方法的奇妙之處,你給這種數(shù)字表達(dá)方法起了名字,補(bǔ)碼,這現(xiàn)代計(jì)算機(jī)系統(tǒng)所采用的數(shù)字表示方法。采用補(bǔ)碼,如果是4個(gè)bit位,那么我們可以表示的范圍是-8 ~ 7。再來(lái)仔細(xì)看一下反碼和補(bǔ)碼:

因?yàn)檠a(bǔ)碼不需要表示 -0 這個(gè)奇葩,你會(huì)發(fā)現(xiàn)一個(gè)很有意思的規(guī)律,那就是負(fù)數(shù)的反碼加上1就是對(duì)應(yīng)的補(bǔ)碼,這是計(jì)算機(jī)教科書(shū)在講解補(bǔ)碼時(shí)很重要的一個(gè)知識(shí)點(diǎn),現(xiàn)在你應(yīng)該知道這個(gè)知識(shí)點(diǎn)是怎么來(lái)的了吧!

CPU真的識(shí)數(shù)嗎?就像前面提到的,現(xiàn)代計(jì)算機(jī)采用補(bǔ)碼的根本原因在于這種表示方法可以簡(jiǎn)化電路設(shè)計(jì),盡管補(bǔ)碼對(duì)人類來(lái)說(shuō)不夠直觀。到這里我們可以看到,在計(jì)算機(jī)科學(xué)中,最符合人類思維的設(shè)計(jì)并不一定對(duì)計(jì)算機(jī)最優(yōu),這也是最迷人的地方,人和機(jī)器畢竟不同嘛!讓我們?cè)賮?lái)看下采用補(bǔ)碼時(shí)2+-2 的計(jì)算過(guò)程:

和十進(jìn)制加法一樣,從右到左,如果產(chǎn)生進(jìn)位,那么進(jìn)位就要參與左邊一列的計(jì)算。注意,在這個(gè)過(guò)程中加法器關(guān)心這個(gè)數(shù)字是正數(shù)還是負(fù)數(shù)了嗎?答案是沒(méi)有,加法器或者更具體是CPU中的ALU根本就不關(guān)心是正數(shù)還是負(fù)數(shù),它只知道我要進(jìn)行加法計(jì)算,除此之外不 CARE 任何其它信息,至于數(shù)字該采用反碼還是補(bǔ)碼這些是人類需要理解的,確切來(lái)說(shuō)是編譯器需要來(lái)理解的,程序員都無(wú)需關(guān)心,但程序員需要知道數(shù)據(jù)類型的表示范圍?,F(xiàn)在你能明白補(bǔ)碼以及 CPU 是如何識(shí)數(shù)的了吧。

總結(jié)在本文我們?cè)敿?xì)講解了CPU是如何識(shí)數(shù)這一主題,正如本文所言,CPU其實(shí)本質(zhì)的上是不識(shí)數(shù)的,也不需要識(shí)數(shù),這正是補(bǔ)碼這一數(shù)字表示方法的優(yōu)點(diǎn)。希望本文能對(duì)大家理解計(jì)算機(jī)系統(tǒng)的數(shù)字表示有所幫助。

責(zé)任編輯:haq

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

    關(guān)注

    68

    文章

    11080

    瀏覽量

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

    關(guān)注

    19

    文章

    7663

    瀏覽量

    90805

原文標(biāo)題:CPU 是如何識(shí)數(shù)的?

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

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

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

    計(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 ?1320次閱讀

    德國(guó)建成歐洲首個(gè)量子計(jì)算機(jī)中

    IBM公司在德國(guó)Ehningen正式揭幕了其量子計(jì)算中心,標(biāo)志著該公司在歐洲的首個(gè)、全球第二個(gè)此類中心的誕生,活動(dòng)吸引了德國(guó)總理舒爾茨的出席。   這座位于Ehningen的計(jì)算機(jī)中心配備了
    的頭像 發(fā)表于 10-08 15:40 ?815次閱讀

    信號(hào)繼電器在計(jì)算機(jī)系統(tǒng)的應(yīng)用

    信號(hào)繼電器在計(jì)算機(jī)系統(tǒng)的應(yīng)用是一個(gè)重要且復(fù)雜的領(lǐng)域,它作為電氣控制的關(guān)鍵元件,在計(jì)算機(jī)系統(tǒng)中發(fā)揮著信號(hào)轉(zhuǎn)換、隔離、放大以及控制等多種作用。以下將從信號(hào)繼電器的基本概念、工作原理、特性、在計(jì)算
    的頭像 發(fā)表于 09-27 16:29 ?940次閱讀

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

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

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

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

    簡(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)和分類
    的頭像 發(fā)表于 08-26 16:23 ?5185次閱讀

    計(jì)算機(jī)中總線的作用是什么

    計(jì)算機(jī)中,總線(Bus)扮演著極其重要的角色,它是計(jì)算機(jī)內(nèi)部各功能部件之間傳送信息的公共通信干線??偩€不僅連接了計(jì)算機(jī)的各個(gè)核心組件,還確保了數(shù)據(jù)、指令和控制信號(hào)的高效、準(zhǔn)確傳輸。
    的頭像 發(fā)表于 08-26 15:57 ?3677次閱讀

    晶體管計(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 ?3616次閱讀

    簡(jiǎn)述計(jì)算機(jī)的I/O控制方式

    計(jì)算機(jī)的I/O(輸入/輸出)控制方式是計(jì)算機(jī)系統(tǒng)至關(guān)重要的部分,它決定了CPU與外設(shè)之間數(shù)據(jù)交換的方式和效率。隨著計(jì)算機(jī)技術(shù)的不斷發(fā)展,I
    的頭像 發(fā)表于 08-20 10:55 ?2372次閱讀

    計(jì)算機(jī)視覺(jué)有哪些優(yōu)缺點(diǎn)

    計(jì)算機(jī)視覺(jué)作為人工智能領(lǐng)域的一個(gè)重要分支,旨在使計(jì)算機(jī)能夠像人類一樣理解和解釋圖像和視頻的信息。這一技術(shù)的發(fā)展不僅推動(dòng)了多個(gè)行業(yè)的變革,也帶來(lái)了諸多優(yōu)勢(shì),但同時(shí)也伴隨著一些挑戰(zhàn)和局限性。以下是對(duì)
    的頭像 發(fā)表于 08-14 09:49 ?2046次閱讀

    邊沿觸發(fā)器在計(jì)算機(jī)中的應(yīng)用

    邊沿觸發(fā)器在計(jì)算機(jī)中的應(yīng)用極為廣泛,它們作為數(shù)字電路的基本單元,對(duì)于實(shí)現(xiàn)計(jì)算機(jī)內(nèi)部的時(shí)序控制、數(shù)據(jù)存儲(chǔ)與傳輸、以及復(fù)雜邏輯功能等方面起著至關(guān)重要的作用。以下將從邊沿觸發(fā)器的定義、特點(diǎn)、工作原理及其在
    的頭像 發(fā)表于 08-12 14:20 ?1293次閱讀

    三態(tài)緩沖器在計(jì)算機(jī)中的應(yīng)用

    電路在不影響其他電路和總線的前提下,能夠靈活地控制其輸出狀態(tài)。以下將詳細(xì)探討三態(tài)緩沖器在計(jì)算機(jī)中的具體應(yīng)用,內(nèi)容將涵蓋其定義、優(yōu)勢(shì)以及在不同計(jì)算機(jī)子系統(tǒng)的具體作用。
    的頭像 發(fā)表于 08-02 17:48 ?1869次閱讀

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

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