成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一文講清楚補碼的本質

開發 前端
在計算機中,所有的數字都是以二進制的形式表示的,即均為 0 和 1 組成的各種編碼,數字的表示形式可以劃分成原碼,反碼和補碼。

[[431951]]

本文轉載自微信公眾號「Linux開發那些事兒」,作者LinuxThings。轉載本文請聯系Linux開發那些事兒公眾號。

在計算機中,所有的數字都是以二進制的形式表示的,即均為 0 和 1 組成的各種編碼,數字的表示形式可以劃分成原碼,反碼和補碼

如何表示 原碼、反碼、補碼

如果沒有特殊說明,下面的介紹都是以 4 位二進制為例的

原碼

為了區分正數和負數,計算機中將二進制的最高位( bit ) 規定為符號位,它等于 0 時表示正數,等于 1 時表示負數,剩下的所有低位( bit )用來表示數值

下面的圖片從左到右分別表示 +5 和 -5 的原碼

反碼

正數的反碼和其原碼相同,負數的反碼在原碼基礎上,符號位不變,數值位取反

下面的圖片從左到右分別表示 +5 和 -5 的反碼

補碼

正數的補碼和其原碼相同,負數的補碼在反碼基礎上加1

下面的圖片從左到右分別表示 +5 和 -5 的補碼

為什么用補碼

在計算機中,數字是以補碼的形式進行存儲和參與運算的

這看起來比較奇怪,為什么要采用補碼這么麻煩的方式表示數字( 特別是對于負數 ),直觀一點兒不好嗎?

為了講明白這個問題,下面我們分別以原碼,反碼和補碼的形式來模擬二進制的加法和減法運算,以 4 位二進制為例來說明

  • 原碼

下圖列出了 4 位二進制所有正數和負數的二進制表示

對于 4 位二進制來說,最高位是符號位,也就是圖中黃色二進制的 0 和 1 的位置

用原碼模擬 3 + 2、6 + (-2) 、(-1) + (-3) 運算,具體的運算過程如下:

上圖中,圓圈中的二進制位是做加法運算的時候向前進位的結果,由于有效二進制位數是 4 位,所以圓圈中的二進制位因溢出而自動丟棄(在計算過程中仍然用到了溢出的二進制位,結果會丟棄溢出的二進制)

由計算過程可知,3 + 2 = 5 是正確的,但是 6 + (-2) = 0 以及 (-1) + (-3) = 4 結果都是錯誤的

所以,原碼雖然直觀易懂,也易于轉換,但是在運算上,正數之間的加法是沒問題,負數之間以及正數和負數之間都存在問題,因此計算機中不能用原碼表示數字

  • 反碼

下面列出了 4 位二進制所有正數和負數的二進制表示,請看下圖

正數的反碼是其自身,負數的反碼是符號位不變,其他位取反,圖中黃色二進制位表示符號位

用反碼模擬 3 + 2、6 + (-2) 、(-1) + (-3) 運算,具體的運算過程如下:

和原碼一樣,上圖中圓圈中的二進制位由于溢出而被自動丟棄,在反碼的運算中,只有 3 + 2 = 5 是正確的,其他的結果都不正確

注意:(-1) + (-3) 的結果是 1010,符號位為 1,表示結果是負數,根據上面負數十進制對應二進制的反碼表可知,它對應的十進制是 -5

由反碼運算結果來看,正數的加法結果是正確的,負數和負數以及正數和負數加法的結果是錯誤的,所以,計算機中也不能用反碼表示數字

  • 補碼

說完了原碼和反碼,現在來看下補碼,下圖是正數和負數補碼的二進制表示

用補碼模擬 3 + 2、6 + (-2) 、(-1) + (-3) 運算,具體的運算過程如下:

由上述計算過程可知,除去溢出的二進制位后,3 + 2、6 + (-2) 、(-1) + (-3) 計算的結果全都正確

用原碼和反碼的表示方式,都不能解決加法運算,但是用補碼表示,不管是正數之間、負數之間還是正數和負數之間的加法,都可以解決

所以,計算機選擇用補碼來表示數字以及用補碼進行運算

補碼的好處

  • 簡化減法計算

補碼在加法或減法處理中,不需因為數字的正負而使用不同的計算方式。只要一種加法電路就可以處理各種有符號數和無符號數加法

而且減法可以用一個數加上另一個數的補碼來表示,因此只要有加法電路及補碼電路即可完成各種有符號數和無符號數加法及減法,在電路設計上相當方便

  • 統一表示數字 0

另外,根據上一小節中,+0 和 -0 的補碼都是 0000,對應的十進制是 0

也就是說 0 的補碼就只有一種表示方式,在計算機中也就有唯一的表示,這和反碼不同(在反碼中,0 有二種二進制表示方式),因此在判斷數字是否為 0 時,只要比較一次即可

由于 +0 和 -0 的補碼只有一種表示方式,即 0000,但是原碼和反碼都有兩種表示方式,所以補碼會多出一種二進制表示方式 1000( 以 4 位二進制為例 ),對應十進制數 -8

補碼是怎么來的

前面講到 負數的補碼是其反碼加 1 , 為什么要這么計算呢, 這么計算就是有效嗎 ?

在十進制中,一個負數可以通過 0 減去一個正數得到,同樣的,二進制中也可以

比如:-3 可以表示成 0 - 3,也可以表示成下面的二進制減法計算

因為 0 ( 0000 ) 小于 3 ( 0011 ),根據算術運算規則,當被減數的位小于減數時,需向前一位借 1,

0000 向前一位借 1 后變成了 1 0000,于是,上面的減法計算就變成了

我們知道, 1 0000 可以表示成 1111 與 1 的和, 也即 1 0000 = 1111 + 1, 于是,計算就變成了

根據上面的計算,0 ( 0000) 減 3(0011) 的結果是 1101, 而 1101 剛好是 -3 的補碼

其實,上面的計算過程就相當于先求反碼然后加 1 , 請看下圖:

用 1111 減去 3 的源碼 0011,結果是 -3 的反碼 1100,然后再加 1 ,得到 -3 的補碼 1101

再看看前面介紹的,負數的補碼等于其反碼加 1,是不是有點兒似曾相識呢,是的,負數的反碼就是這么來的,它并不是一個毫無根據的定義,而是通過上面的計算一步一步得出來的,只不過補碼的計算方式剛好是其反碼加 1 而已

為什么補碼適合正數的加法

我們還是以 4 位二進制為例來進行說明

假如有兩個正數 A 和 B,現在要證明 A 減 B 的結果等于 A 加上 B 的補碼

減去一個數等于加上一個負數,所以 A - B = A + ( 0 - B )

由上一小節可知, ( 0 - B ) 等價于 ( 1111 - B ) + 1

所以,A 加 B 的補碼就等于 A + ( 1111 - B ) + 1,假如結果為 R ,則有 R = A + ( 1111 - B ) + 1

A + ( 1111 - B ) + 1 可以寫成 A - B + ( 1111 + 1 )

A - B + ( 1111 + 1 ) 又可以寫成 A - B + 1 0000 ( 1111 + 1 = 1 0000 )

我們是以 4 位二進制為例的, 1 0000 已經超過 4 位了,所以加 1 0000 時,最高位會因溢出而被丟棄

其實這時 1 0000 就相當于 0000 了(最高位溢出,需要丟棄)

所以,上面的計算

  1. R = A + ( 1111 - B ) + 1 
  2.   = A - B + ( 1111 + 1 )  
  3.   = A - B + 1 0000 
  4.   = A - B +   0000 
  5.   = A - B 

這樣就證明了 A 減 B 等于 A 加上 B 的補碼

小結

本文介紹了原碼、反碼以及補碼,重點闡述了補碼的由來以及證明了補碼計算正數加法的可行性。

 

責任編輯:武曉燕 來源: Linux開發那些事兒
相關推薦

2018-05-21 07:08:18

行為驅動開發BDD編碼

2024-02-23 10:41:29

2025-05-06 09:30:00

DevOps云原生開發

2020-10-26 09:18:50

RedisCluste

2018-08-13 09:20:21

NoSQLSQL數據

2020-07-29 09:21:34

Docker集群部署隔離環境

2021-07-05 22:22:24

協議MQTT

2017-12-17 20:17:23

NoSQLSQL數據

2020-04-01 17:26:57

MySQL事務隔離級別數據庫

2019-06-20 17:49:51

RPCHTTP協議

2019-07-07 08:18:10

MySQL索引數據庫

2022-01-05 09:27:24

讀擴散寫擴散feed

2021-04-21 10:00:08

MySQL索引數據庫

2024-01-05 07:55:39

Linux虛擬內存

2020-03-26 09:18:54

高薪本質因素

2024-04-01 10:09:23

AutowiredSpring容器

2021-10-19 10:10:51

MySQL事務隔離級別數據庫

2019-01-31 09:20:36

架構容錯架構分布式容錯

2025-03-03 08:40:00

JavaScriptthis開發

2024-07-01 13:45:18

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产91亚洲精品 | 最新中文字幕在线播放 | 日韩欧美精品一区 | 丁香综合 | 欧美free性| 精品国产一区二区三区成人影院 | 国产精品久久久久久久久久免费看 | 美日韩视频| 久久精品小视频 | 国产一区二区在线视频 | 超碰一区二区 | 免费成人av | 综合久久99 | 精品美女视频在线观看免费软件 | 久久久久久久国产精品影院 | 精品久久久久久亚洲国产800 | 一区二区av | 日韩欧美三级在线 | 午夜精品久久久久久久久久久久 | 丝袜 亚洲 另类 欧美 综合 | 九九九精品视频 | 中文字幕一区二区三区四区五区 | 国产免费视频 | 天堂中文av| 欧美久久免费观看 | 日韩一区不卡 | 色悠悠久 | 亚洲日本欧美 | av色站| 久久av一区二区三区 | 成人精品国产一区二区4080 | 精品亚洲一区二区 | 亚洲91 | 国产精品一区二区三 | 国产欧美一区二区精品久导航 | 人人干人人干人人 | 玖玖在线精品 | 干干干操操操 | 国产一区二区免费 | 99视频免费看 | 日韩精品在线观看一区二区三区 |