[導讀]先來看一個簡單的問題:小孩子都知道數(shù)數(shù):1,2,3,4,5,6,7,8,9,10,可為什么要這樣數(shù)呢?為什么不是1,2,3,4,5,6,10呢?一種比較流行的解釋是因為人類有10個手指:所以人類的數(shù)字系統(tǒng)就是10進制的,如果這個解釋成立,那么變色龍的數(shù)字系統(tǒng)應(yīng)該是4進制:而計算機...
先來看一個簡單的問題:小孩子都知道數(shù)數(shù):1,2,3,4,5,6,7,8,9,10,可為什么要這樣數(shù)呢?為什么不是1,2,3,4,5,6,10呢?
一種比較流行的解釋是因為人類有10個手指:
所以人類的數(shù)字系統(tǒng)就是10進制的,如果這個解釋成立,那么變色龍的數(shù)字系統(tǒng)應(yīng)該是4進制:而計算機的手是單指,所以是2進制:哈哈,開個玩笑,其實計算機在最最最最底層就是一個個開關(guān),因此計算機系統(tǒng)是2進制,關(guān)于CPU的構(gòu)造你可以參考《你管這破玩意叫 CPU?》:
數(shù)字 0 與正整數(shù)
0這個數(shù)字其實有非常重要的意義,可能大家都沒想過這個問題,沒關(guān)系,我們來看兩個不同的數(shù)字系統(tǒng):阿拉伯數(shù)字和羅馬數(shù)字:注意,羅馬數(shù)字中沒有 “0” 這個概念,你可能會想,這有什么大不了的嗎?讓我們來看一個例子,數(shù)字205,分別在兩種系統(tǒng)的表示。羅馬:CCV阿拉伯:2050的出現(xiàn)可以讓阿拉伯數(shù)字系統(tǒng)中205這樣寫:可以看到,在阿拉伯系統(tǒng)中數(shù)值和數(shù)字所在的位置有直接關(guān)系,這就是進位制,而在羅馬數(shù)字系統(tǒng)則沒有進位制,這使得羅馬數(shù)字在表示大數(shù)值時非常困難。計算機系統(tǒng)中的二進制同樣是進位制,數(shù)字5用二進制表示就是101:使用 k 個bit,那么可以表示 2^k 個整數(shù),范圍從 0 到 2^k - 1,假設(shè) k 有 8 位,那么表示范圍就是 0 到 255,當然這里說的是無符號正整數(shù)。現(xiàn)在我們可以表示正整數(shù)了,但真正有用的計算不可避免會涉及到負數(shù),也就是帶符號整數(shù),而這也是真正有趣的地方。
有符號整數(shù)
正整數(shù)的表示非常簡單,給定 k 個bit,那么我們可以表示 2^k 個數(shù),假設(shè)k為4,那么我們可以表示16個數(shù)字。如果要考慮有符號整數(shù)呢?你可能會想這還不簡單,一半一半嘛!其中一半用來表示正數(shù),另一半用來表示負數(shù)!假設(shè)有4個比特位,如果用來表示無符號正數(shù),就是0 ~ 15,而如果要表示有符號整數(shù),那么其中一半給到 1 ~ 7,另一半給到-1 ~ -7,一切看最左邊的 bit 是 0,如果最左邊的 bit 位是 0 則表示正數(shù),否則表示負數(shù)。現(xiàn)在我們已經(jīng)知道正負數(shù)是通過什么來決定的了,接下來的問題就是負數(shù)該怎么表示呢?也就是說對于比如-2,現(xiàn)在我們只知道其最左邊的 bit 位是1,那么右邊的這些 bit 到底該是多少呢?關(guān)于這一問題就三種設(shè)計方法。
方法1:正數(shù)加上負號即對應(yīng)負數(shù)
第一種設(shè)計方法很簡單,既然0010表示 2,那么如果最左邊的bit位替換成1就表示對應(yīng)的負數(shù),即1010表示-2,這種設(shè)計方法簡單直接,這是最符合人類的思維的設(shè)計(不一定最好)。如果這樣設(shè)計的話,4個 bit 位能表示的所有數(shù)字就是:你給這種非常符合人類思維的數(shù)字表示方法起了個名字,原碼。這種設(shè)計下會有一個奇怪的表示:0000表示0這沒什么問題,1000會表示 -0,這會導致出現(xiàn)-0這樣的數(shù)字,其實 0 和 -0 不應(yīng)該有什么區(qū)別。身為設(shè)計天才的你顯然不滿足于此,是不是還有其它設(shè)計方法?
方法2:翻轉(zhuǎn)
你覺得第一種表示方法也就是原碼太原始,可以說基本上沒什么設(shè)計,你突發(fā)奇想,既然0010表示 2,那么將其全部翻轉(zhuǎn),即1101來表示-2好了,即:你給這種表示方法也起了名字,反碼。在反碼表示法下,也存在-0,0000表示0,全部翻轉(zhuǎn)也就是1111來表示-0,可以看到這和原碼表示方法差別沒那么大。
設(shè)計計算機很容易嗎?
到這里有的同學可能會想,計算機設(shè)計者其實怎么來表示有符號數(shù)其實都是可以的,原碼可以,反碼也可以,都能表示出來,設(shè)計計算機太容易了吧!你猜的沒錯,就是這么容易!如果你是計算機的創(chuàng)造者,怎么設(shè)計都可以!最初的計算機設(shè)計者真的可以有很多表示數(shù)字的方法,采用反碼表示數(shù)字的計算機系統(tǒng)在歷史上真的出現(xiàn)過!??!但這些表示方法不約而同都有一個問題,那就是兩數(shù)相加。
不簡單的兩數(shù)相加
我們以2 ( -2 )為例。在原碼表示法下,2為0010,-2為1010,那么計算機該怎么做2 ( -2 )加法呢?可是1100在原碼表示法下是 -4,這與原碼表示法本身是矛盾的。再來看看反碼,2為0010,-2為1101,兩數(shù)相加:1111在反碼表示下為-0,雖然-0不夠優(yōu)雅,但好歹和反碼表示法本身沒有矛盾,這大概就是為什么早期會有計算機采用反碼表示數(shù)字的原因。在《你管這破玩意叫CPU?》一文中我們知道,計算機加法是通過加法器組合電路實現(xiàn)的,而這里的不管是原碼還是反碼,要想計算加法都不可避免的要在前面提到的加法器之上額外添加組合電路來確保有符號數(shù)相加的正確性,這無疑會增加電路設(shè)計的復雜度。人是懶惰的也是聰明的,我們就沒有一種2 -2就是0(0000)的數(shù)字表達方法嗎?
新的表示方法
現(xiàn)在,對于最左邊的bit位來說,0表示正數(shù),1表示負數(shù)是沒有什么異議的,這里的關(guān)鍵在于我們需要一種表示方法,可以讓A (-A) = 0,而且這里0的二進制也是0,如果是4個bit為的話就應(yīng)該是0000。假設(shè)A=2,那么我們重點研究下2 -2 = 0(0000)的表示方法。對于2來說,很簡單就是0010,對于-2來說,現(xiàn)在我們只能確定最左邊的bit位是1,也就是說 :顯然 -2 應(yīng)該用1110來表示,這樣2 -2就真的是0了,由此推斷:從圖中可以看出這種表示方法下就沒有-0了。注意看-1和0,分別是1111和0000,當我們讓-1(1111)加上1(0001)時,我們確實得到了0000,不過還有一個進位,實際上我們得到的是10000,但我們可以放心的忽略掉該進位。這種表示方法最美妙的地方在于《你管這破玩意叫CPU》一文中提到的加法器不用修改就可以直接計算有符號數(shù)字的加法。你可以自己試驗幾個數(shù)字相加就能發(fā)下這種表示方法的奇妙之處,你給這種數(shù)字表達方法起了名字,補碼,這現(xiàn)代計算機系統(tǒng)所采用的數(shù)字表示方法。采用補碼,如果是4個bit位,那么我們可以表示的范圍是-8 ~ 7。再來仔細看一下反碼和補碼:因為補碼不需要表示 -0 這個奇葩,你會發(fā)現(xiàn)一個很有意思的規(guī)律,那就是負數(shù)的反碼加上1就是對應(yīng)的補碼,這是計算機教科書在講解補碼時很重要的一個知識點,現(xiàn)在你應(yīng)該知道這個知識點是怎么來的了吧!
CPU真的識數(shù)嗎?
就像前面提到的,現(xiàn)代計算機采用補碼的根本原因在于這種表示方法可以簡化電路設(shè)計,盡管補碼對人類來說不夠直觀。到這里我們可以看到,在計算機科學中,最符合人類思維的設(shè)計并不一定對計算機最優(yōu),這也是最迷人的地方,人和機器畢竟不同嘛!讓我們再來看下采用補碼時2 -2 的計算過程:和十進制加法一樣,從右到左,如果產(chǎn)生進位,那么進位就要參與左邊一列的計算。注意,在這個過程中加法器關(guān)心這個數(shù)字是正數(shù)還是負數(shù)了嗎?答案是沒有,加法器或者更具體是CPU中的ALU根本就不關(guān)心是正數(shù)還是負數(shù),它只知道我要進行加法計算,除此之外不 CARE 任何其它信息,至于數(shù)字該采用反碼還是補碼這些是人類需要理解的,確切來說是編譯器需要來理解的,程序員都無需關(guān)心,但程序員需要知道數(shù)據(jù)類型的表示范圍。現(xiàn)在你能明白補碼以及 CPU 是如何識數(shù)的了吧。
總結(jié)
在本文我們詳細講解了CPU是如何識數(shù)這一主題,正如本文所言,CPU其實本質(zhì)的上是不識數(shù)的,也不需要識數(shù),這正是補碼這一數(shù)字表示方法的優(yōu)點。希望本文能對大家理解計算機系統(tǒng)的數(shù)字表示有所幫助。------------ END ------------
本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
由臺達集團于2026年3月29日通過美通社發(fā)布新聞稿《集裝箱式SST直流移動智算中心發(fā)布》中,第3張有誤,已進行替換。特此更正,更新后的全文及圖片如下: 集裝箱式SST直流移動智算中心發(fā)布 臺達、漢騰科技、龍芯中科攜...
關(guān)鍵字:
移動
ST
固態(tài)變壓器
CPU
面對AI Agent與Physical AI的浪潮,單純依靠增加GPU或NPU的補丁式方案已難以為繼,CPU架構(gòu)必須進行面向AI的底層重塑。
阿里達摩院發(fā)布的玄鐵C950旗艦處理器,不僅刷新了單核性能紀錄,更通過原生A...
關(guān)鍵字:
玄鐵C950
CPU
AI
物理AI
RISC-V
北京2026年3月27日 /美通社/ -- 當?shù)谑鍖萌珖\動會辦公系統(tǒng)全程穩(wěn)定運行時,當銀行柜員輕點鼠標實現(xiàn)業(yè)務(wù)秒級響應(yīng)時,當大學生刷一卡通順暢進出宿舍、食堂、圖書館時,當新能源汽車充電樁智能調(diào)度、巨災(zāi)預警系統(tǒng)精準響應(yīng)...
關(guān)鍵字:
CPU
指令集
芯片
操作系統(tǒng)
成立三十余年來,Arm一直是芯片行業(yè)特殊的“幕后推手”——不生產(chǎn)一顆芯片,卻定義了全球99%智能手機的底層架構(gòu)。然而,這家長期保持中立的IP授權(quán)巨頭,如今正打破自己一手建立的商業(yè)規(guī)則。
關(guān)鍵字:
ARM
CPU
芯片
Arm 首次將其平臺矩陣拓展至量產(chǎn)芯片產(chǎn)品,為業(yè)界提供覆蓋 IP、Arm計算子系統(tǒng) (CSS)及芯片的最廣泛的計算產(chǎn)品選擇。
發(fā)布首款由 Arm 設(shè)計的數(shù)據(jù)中心 CPU——Arm AGI CPU,專為代理式AI 基...
關(guān)鍵字:
ARM
CPU
數(shù)據(jù)中心
代理式AI
2026年3月24日,美國加州圣何塞訊——Super Micro Computer, Inc.(NASDAQ:SMCI)作為云端計算、AI/機器學習、存儲和5G/邊緣領(lǐng)域的全方位IT解決方案供應(yīng)商,宣布推出基于NVIDI...
關(guān)鍵字:
DCBBS液冷架構(gòu)
CPU
存儲
3月24日,由阿里巴巴達摩院主辦的2026玄鐵RISC-V生態(tài)大會在上海舉行。高通、Arteris、Canonical、SHD Group、海爾、中興通訊、全志科技、北京智芯微、南芯科技等全球數(shù)百家產(chǎn)學研機構(gòu)齊聚一堂,分...
關(guān)鍵字:
RISC-V
CPU
算力
Supermicro的NVIDIA Vera Rubin NVL72與HGX Rubin NVL8系統(tǒng)是基于DCBBS液冷架構(gòu)所設(shè)計,與NVIDIA Blackwell...
關(guān)鍵字:
CPU
MICRO
NVIDIA
SUPER
3月24日消息,今日,在上海舉行的2026玄鐵RISC-V生態(tài)大會上,阿里巴巴達摩院發(fā)布新一代旗艦CPU產(chǎn)品玄鐵C950。
關(guān)鍵字:
RISC-V
CPU
March 18, 2026 ---- 根據(jù)TrendForce集邦咨詢最新AI Server研究,在大型云端服務(wù)供應(yīng)商(CSP)加大自研芯片力道的情況下,NVIDIA(英偉達)在GTC 2026大會改為著重各領(lǐng)域的AI...
關(guān)鍵字:
ASIC
GPU
CPU
可擴展邊緣計算性能,從容應(yīng)對嚴苛應(yīng)用挑戰(zhàn)
關(guān)鍵字:
邊緣計算
CPU
GPU
NVIDIA Vera CPU 為大規(guī)模數(shù)據(jù)處理、AI 訓練和智能體式推理提供最高性能與能效
關(guān)鍵字:
數(shù)據(jù)處理
AI
CPU
近日,國產(chǎn)筆記本品牌馳為(CHUWI)深陷“CPU造假”風波——繼其CoreBook X機型被曝用老款銳龍5 5500U冒充新款7430U之后,另一款CoreBook Plus也以完全相同的手法翻車了。
關(guān)鍵字:
CPU
【2026年3月12日,德國慕尼黑訊】隨著汽車行業(yè)向軟件定義汽車(SDV)轉(zhuǎn)型,網(wǎng)絡(luò)安全已成為保護車輛生態(tài)系統(tǒng)、主機廠(OEM)知識產(chǎn)權(quán)及終端客戶隱私的關(guān)鍵。為滿足這一需求,英飛凌科技股份公司(FSE代碼:IFX / O...
關(guān)鍵字:
微控制器
CPU
非易失性存儲器
隨著人工智能從云端向端側(cè)加速滲透,芯片設(shè)計面臨的復雜度與日俱增。企業(yè)不僅需要領(lǐng)先的技術(shù)支撐,更需要在成本控制、風險管理和開發(fā)效率之間找到平衡。Arm技術(shù)授權(quán)訂閱模式通過Arm Flexible Access、Arm To...
關(guān)鍵字:
人工智能
芯片設(shè)計
CPU
March 10, 2026 ---- 根據(jù)TrendForce集邦咨詢最新筆電產(chǎn)業(yè)研究,2026年全球筆電市場正面臨需求疲弱、成本上升的雙重壓力,除了存儲器價格快速攀升,CPU價格也開始上調(diào)。據(jù)TrendForce集邦...
關(guān)鍵字:
筆電
存儲器
CPU
為COM-HPC Client 平臺帶來更強悍、更穩(wěn)定的性能表現(xiàn)
關(guān)鍵字:
邊緣計算
CPU
GPGPU
高性能計算分支預測失敗就像隱藏在代碼中的定時炸彈,當CPU流水線遇到條件分支時,現(xiàn)代處理器雖然能以95%以上的準確率預測執(zhí)行路徑,但剩余5%的錯誤仍會導致10-15個周期的流水線清空。在關(guān)鍵計算場景中,這種看似微小的失敗...
關(guān)鍵字:
if-else
CPU
在Linux系統(tǒng)中,進程管理是內(nèi)核的核心功能之一,其核心目標是通過高效的調(diào)度機制和進程切換技術(shù),實現(xiàn)多任務(wù)并發(fā)執(zhí)行。
關(guān)鍵字:
Linux
CPU
Jan. 26, 2026 ---- 根據(jù)TrendForce集邦咨詢最新筆電產(chǎn)業(yè)調(diào)查,全球筆電品牌自2025年下半年起面臨存儲器價格顯著上漲的壓力,2026年初開始,又遭遇CPU階段性供給缺口、價格調(diào)漲的壓力,加上包括...
關(guān)鍵字:
筆電
CPU
存儲器