在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

計算機中CPU是如何識數的

strongerHuang ? 來源:Python數據科學 ? 作者:東哥起飛 ? 2021-10-08 16:38 ? 次閱讀

先來看一個簡單的問題:小孩子都知道數數:1,2,3,4,5,6,7,8,9,10,可為什么要這樣數呢?為什么不是1,2,3,4,5,6,10呢?

一種比較流行的解釋是因為人類有10個手指,所以人類的數字系統就是10進制的,如果這個解釋成立,那么變色龍的數字系統應該是4進制,而計算機的手是單指,所以是2進制。

哈哈,開個玩笑,其實計算機在最最最最底層就是一個個開關,因此計算機系統是2進制,關于CPU的構造你可以參考《你管這破玩意叫 CPU?》:

數字 0 與正整數

0這個數字其實有非常重要的意義,可能大家都沒想過這個問題,沒關系,我們來看兩個不同的數字系統:阿拉伯數字和羅馬數字。

注意,羅馬數字中沒有 “0” 這個概念,你可能會想,這有什么大不了的嗎?讓我們來看一個例子,數字205,分別在兩種系統的表示。羅馬:CCV阿拉伯:2050的出現可以讓阿拉伯數字系統中205這樣寫。

可以看到,在阿拉伯系統中數值和數字所在的位置有直接關系,這就是進位制,而在羅馬數字系統則沒有進位制,這使得羅馬數字在表示大數值時非常困難。計算機系統中的二進制同樣是進位制,數字5用二進制表示就是101。

使用 k 個bit,那么可以表示 2^k 個整數,范圍從 0 到 2^k - 1,假設 k 有 8 位,那么表示范圍就是 0 到 255,當然這里說的是無符號正整數。現在我們可以表示正整數了,但真正有用的計算不可避免會涉及到負數,也就是帶符號整數,而這也是真正有趣的地方。

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

現在我們已經知道正負數是通過什么來決定的了,接下來的問題就是負數該怎么表示呢?也就是說對于比如-2,現在我們只知道其最左邊的 bit 位是1,那么右邊的這些 bit 到底該是多少呢?關于這一問題就三種設計方法。

方法1:正數加上負號即對應負數第一種設計方法很簡單,既然0010表示+2,那么如果最左邊的bit位替換成1就表示對應的負數,即1010表示-2,這種設計方法簡單直接,這是最符合人類的思維的設計(不一定最好)。如果這樣設計的話

你給這種非常符合人類思維的數字表示方法起了個名字,原碼。這種設計下會有一個奇怪的表示:0000表示0這沒什么問題,1000會表示 -0,這會導致出現-0這樣的數字,其實 0 和 -0 不應該有什么區別。身為設計天才的你顯然不滿足于此,是不是還有其它設計方法?

方法2:翻轉你覺得第一種表示方法也就是原碼太原始,可以說基本上沒什么設計,你突發奇想,既然0010表示+2,那么將其全部翻轉,即1101來表示-2好了,你給這種表示方法也起了名字,反碼。在反碼表示法下,也存在-0,0000表示0,全部翻轉也就是1111來表示-0,可以看到這和原碼表示方法差別沒那么大。

設計計算機很容易嗎?到這里有的同學可能會想,計算機設計者其實怎么來表示有符號數其實都是可以的,原碼可以,反碼也可以,都能表示出來,設計計算機太容易了吧!你猜的沒錯,就是這么容易!如果你是計算機的創造者,怎么設計都可以!最初的計算機設計者真的可以有很多表示數字的方法,采用反碼表示數字的計算機系統在歷史上真的出現過!!!但這些表示方法不約而同都有一個問題,那就是兩數相加。

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

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

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

新的表示方法現在,對于最左邊的bit位來說,0表示正數,1表示負數是沒有什么異議的,這里的關鍵在于我們需要一種表示方法,可以讓A+(-A) = 0,而且這里0的二進制也是0,如果是4個bit為的話就應該是0000。假設A=2,那么我們重點研究下2+-2 = 0(0000)的表示方法。對于2來說,很簡單就是0010,對于-2來說,現在我們只能確定最左邊的bit位是1。

顯然 -2 應該用1110來表示,這樣2+-2就真的是0了,由此推斷:

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

因為補碼不需要表示 -0 這個奇葩,你會發現一個很有意思的規律,那就是負數的反碼加上1就是對應的補碼,這是計算機教科書在講解補碼時很重要的一個知識點,現在你應該知道這個知識點是怎么來的了吧!

CPU真的識數嗎?就像前面提到的,現代計算機采用補碼的根本原因在于這種表示方法可以簡化電路設計,盡管補碼對人類來說不夠直觀。到這里我們可以看到,在計算機科學中,最符合人類思維的設計并不一定對計算機最優,這也是最迷人的地方,人和機器畢竟不同嘛!讓我們再來看下采用補碼時2+-2 的計算過程:

和十進制加法一樣,從右到左,如果產生進位,那么進位就要參與左邊一列的計算。注意,在這個過程中加法器關心這個數字是正數還是負數了嗎?答案是沒有,加法器或者更具體是CPU中的ALU根本就不關心是正數還是負數,它只知道我要進行加法計算,除此之外不 CARE 任何其它信息,至于數字該采用反碼還是補碼這些是人類需要理解的,確切來說是編譯器需要來理解的,程序員都無需關心,但程序員需要知道數據類型的表示范圍。現在你能明白補碼以及 CPU 是如何識數的了吧。

總結在本文我們詳細講解了CPU是如何識數這一主題,正如本文所言,CPU其實本質的上是不識數的,也不需要識數,這正是補碼這一數字表示方法的優點。希望本文能對大家理解計算機系統的數字表示有所幫助。

責任編輯:haq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • cpu
    cpu
    +關注

    關注

    68

    文章

    11012

    瀏覽量

    215286
  • 計算機
    +關注

    關注

    19

    文章

    7608

    瀏覽量

    89876

原文標題:CPU 是如何識數的?

文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    工業中使用哪種計算機

    在工業環境,工控機被廣泛使用。這些計算機的設計可承受極端溫度、灰塵和振動等惡劣條件。它們比標準消費類計算機更耐用、更可靠。工業計算機可控制機器、監控流程并實時收集數據。其堅固的結構和
    的頭像 發表于 11-29 14:07 ?534次閱讀
    工業中使用哪種<b class='flag-5'>計算機</b>?

    量子計算機與普通計算機工作原理的區別

    ? 本文介紹了量子計算機與普通計算機工作原理的區別。 量子計算是一個新興的研究領域,科學家們利用量子力學,制造出具有革命性能力的計算機。雖然現在的量子
    的頭像 發表于 11-24 11:00 ?1110次閱讀
    量子<b class='flag-5'>計算機</b>與普通<b class='flag-5'>計算機</b>工作原理的區別

    計算機接口位于什么之間

    計算機接口是計算機硬件和軟件之間、計算機與外部設備之間以及計算機各部件之間傳輸數據、控制信息和狀態信息的硬件設備和軟件程序。它在計算機系統
    的頭像 發表于 10-14 14:02 ?913次閱讀

    德國建成歐洲首個量子計算機中

    IBM公司在德國Ehningen正式揭幕了其量子計算中心,標志著該公司在歐洲的首個、全球第二個此類中心的誕生,活動吸引了德國總理舒爾茨的出席。   這座位于Ehningen的計算機中心配備了
    的頭像 發表于 10-08 15:40 ?656次閱讀

    信號繼電器在計算機系統的應用

    信號繼電器在計算機系統的應用是一個重要且復雜的領域,它作為電氣控制的關鍵元件,在計算機系統中發揮著信號轉換、隔離、放大以及控制等多種作用。以下將從信號繼電器的基本概念、工作原理、特性、在計算
    的頭像 發表于 09-27 16:29 ?752次閱讀

    計算機存儲系統的構成

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

    簡述計算機總線的分類

    計算機總線作為計算機系統連接各個功能部件的公共通信干線,其結構和分類對于理解計算機硬件系統的工作原理至關重要。以下是對計算機總線結構和分類
    的頭像 發表于 08-26 16:23 ?4412次閱讀

    計算機中總線的作用是什么

    計算機中,總線(Bus)扮演著極其重要的角色,它是計算機內部各功能部件之間傳送信息的公共通信干線。總線不僅連接了計算機的各個核心組件,還確保了數據、指令和控制信號的高效、準確傳輸。
    的頭像 發表于 08-26 15:57 ?3015次閱讀

    簡述計算機的I/O控制方式

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

    邊沿觸發器在計算機中的應用

    邊沿觸發器在計算機中的應用極為廣泛,它們作為數字電路的基本單元,對于實現計算機內部的時序控制、數據存儲與傳輸、以及復雜邏輯功能等方面起著至關重要的作用。以下將從邊沿觸發器的定義、特點、工作原理及其在
    的頭像 發表于 08-12 14:20 ?1020次閱讀

    三態緩沖器在計算機中的應用

    電路在不影響其他電路和總線的前提下,能夠靈活地控制其輸出狀態。以下將詳細探討三態緩沖器在計算機中的具體應用,內容將涵蓋其定義、優勢以及在不同計算機子系統的具體作用。
    的頭像 發表于 08-02 17:48 ?1631次閱讀

    DRAM在計算機中的應用

    DRAM(Dynamic Random Access Memory,動態隨機存取存儲器)在計算機系統扮演著至關重要的角色。它是一種半導體存儲器,用于存儲和快速訪問數據,是計算機主內存的主要組成部分。以下是對DRAM在
    的頭像 發表于 07-24 17:04 ?2349次閱讀

    計算機系統的關鍵組件有哪些

    計算機系統,關鍵組件的協同工作構成了其強大的數據處理和運算能力。這些組件不僅決定了計算機的性能,還影響著用戶的使用體驗。以下是對計算機系統
    的頭像 發表于 07-15 18:18 ?2230次閱讀

    工業控制計算機的特點 工業控制計算機的應用領域

    工業控制計算機是一種專門為工業自動化和控制系統設計的計算機。它具有高度的可靠性、穩定性和實時性,能夠滿足工業生產過程對控制精度和響應速度的嚴格要求。 工業控制計算機的特點 高可靠性
    的頭像 發表于 06-16 11:30 ?1897次閱讀

    工業計算機與普通計算機的區別

    在信息化和自動化日益發展的今天,計算機已經成為了我們日常生活和工作不可或缺的工具。然而,在計算機領域中,工業計算機和普通計算機雖然都具備基
    的頭像 發表于 06-06 16:45 ?2154次閱讀
    主站蜘蛛池模板: 在线观看一区二区三区视频 | xxxx性欧美高清 | 色播四房间 | 日本特黄a级高清免费酷网 日本特黄色大片 | 一级做a爰片久久毛片毛片 一级做a爰片久久毛片美女图片 | 日韩1| 午夜影院入口 | 轻点太大了好深好爽h文 | 黄色欧美视频 | 久久久美女视频 | 在线天堂中文新版有限公司 | 俄罗斯一级特黄黄大片 | 久久e热| 好男人www社区影视在线 | 天天操天天干天天摸 | 一级日本大片免费观看视频 | 午夜视频免费看 | 久久免费精品国产72精品剧情 | 欧美亚洲三级 | 亚洲伊人色一综合网 | 日本视频色 | 午夜影院美女 | 日本sese | 日韩毛片免费线上观看 | 天堂在线中文字幕 | 亚洲韩国欧美一区二区三区 | 她也啪97在线视频 | 中文在线最新版天堂 | 亚洲伊人成综合成人网 | 91欧美精品激情在线观看 | 色噜噜久久 | 国产特黄1级毛片 | 欧美一级在线免费观看 | 免费视频www| 日本欧美午夜 | 日本精品视频 | 国产精品香蕉成人网在线观看 | 国产日日操 | 九色综合九色综合色鬼 | 伊人黄| 激情性爽三级成人 |