當(dāng)前位置:首頁 > 原創(chuàng) > 振南技術(shù)干貨集(風(fēng)云錄)
[導(dǎo)讀]補(bǔ)碼是一個(gè)很基礎(chǔ)的概念,但是對于很多人來說,其實(shí)有些迷糊,這里對補(bǔ)碼進(jìn)行一些通俗而深刻的講解。

關(guān)于補(bǔ)碼

補(bǔ)碼是一個(gè)很基礎(chǔ)的概念,但是對于很多人來說,其實(shí)有些迷糊,這里對補(bǔ)碼進(jìn)行一些通俗而深刻的講解。

C語言中的整型類型有兩種,無符號與有符號。無符號比較好理解,如圖2.8所示。

圖2.8 無符號整型的數(shù)值表達(dá)

只需要將每一個(gè)位乘以它的權(quán)值,再求和即是其所表達(dá)的數(shù)值。它所有的位都用來表達(dá)數(shù)值,因此上圖中類型能表達(dá)的范圍為0~255(8個(gè)位)。但是如何表達(dá)負(fù)數(shù),比如-10,這個(gè)時(shí)候就涉及到補(bǔ)碼了,如圖2.9所示。

圖2.9 有符號整型的數(shù)值表達(dá)

有符號整型的最高位被定義為符號位,0為正數(shù),1為負(fù)數(shù)。上圖中前一行等于+76,后一行等于多少?-76?那就錯(cuò)了。對于負(fù)數(shù)的數(shù)值要按其補(bǔ)碼來計(jì)算,如圖2.10所示。

圖2.10 有符號整型負(fù)數(shù)數(shù)值計(jì)算方法

為什么要引入補(bǔ)碼的概念,符號位表示符號,其它位直接表示其絕對值,不是更好嗎?這其實(shí)是一個(gè)數(shù)字游戲。我們要知道一個(gè)前提:CPU中只有加法器,而沒有減法器。OK,我們看下面的例子。

圖2.11 使用補(bǔ)碼通過加法實(shí)現(xiàn)減法操作

可以看到,補(bǔ)碼將符號位也統(tǒng)一到了計(jì)算過程中,并且巧妙的使用加法實(shí)現(xiàn)了減法操作。這對于簡化CPU中的算術(shù)邏輯電路(ALU)具有重要意義。

關(guān)于-1

為了說明關(guān)于-1的問題,我們先來看一個(gè)例子:

signed short a=-1;

if(-1==a)

{

//....

}

這個(gè)if條件成立嗎?似乎這是一句廢話。其實(shí)不然,它不一定成立。

我們要知道C語言中的判等==運(yùn)算是一種強(qiáng)匹配,也就是比較的雙方必須每一個(gè)位都匹配才被認(rèn)為相等。上例中,a在內(nèi)存中的表示是0XFFFF(補(bǔ)碼),但是-1這個(gè)常量在內(nèi)存中的表示在不同的硬件平臺(tái)上卻不盡相同,在16位CPU平臺(tái)上是0XFFFF,它們是相等的。而在32位CPU平臺(tái)上則是0XFFFFFFFF,它們就不相等。所以穩(wěn)妥的辦法是:

signed short a=-1;

if(((signed short)-1)==a)

{

//....

}

我們看到-1的補(bǔ)碼是全F,而且位數(shù)與CPU平臺(tái)相關(guān)。所以-1經(jīng)常還有另一個(gè)妙用,即可以用于判斷硬件平臺(tái)的CPU位數(shù),便于提高代碼的可移植性(32位平臺(tái)的int(-1)為0XFFFFFFFF,而16位平臺(tái)則是0XFFFF)。

聲明:該篇文章為本站原創(chuàng),未經(jīng)授權(quán)不予轉(zhuǎn)載,侵權(quán)必究。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉