计算机基础之补码原理

首先

我们都知道负数在计算机中是以补码表示的,如果不知道请看上回分解那为什么呢?要了解补码原理首先要理解算术中**“模”**的概念

1 模(Modulo)

1.1 什么是模数

Modular arithmetic: Part of a system of arithmetic for integers, where numbers “wrap around” upon reaching a certain value—the modulus
————WIKIPEDIA

1.1.1 释义

模是指一个计量系统的技术==计数范围。比如时钟,计算机也是一个计算器,它也是有计量范围的,也即都存在一个“模”。
如时钟的计量范围是0~11,模=12.
32位计算机的计量范围是2^32 ,模=2^32.
64位计算机的计量范围就是2^64, 模=2^64.
“模”是计量器产生“溢出”的量,它的值在计算器上表示不出来,计算器上只能表示出模的余数,如12的余数有0,1,2,3,4,5,6,7,8,9,10,11.

1.2 补数

假设当前时针指向11点,而准确时间是8点,调整时间可有以下两种拨法:

一种是倒拨3小时,即:11-3=8
另一种是顺拨9小时:11+9=12+8=8

在以模为12的系统中,加9和减3效果是一样的,因此凡是减3运算,都可以用加9来代替。对“模”12而言,9和3互为补数(二者相加等于模)。所以我们可以得出一个结论,即在有模的计量系统中,减一个数等于加上它的补数,从而实现将减法运算转化为加法运算的目的。

补码原理

计算机上的补码就是算术里的补数。
设我们有一个 4 位的计算机,则其计量范围即模是
2^4 = 16,所以其能够表示的范围是0~15,现在以计算 5 - 3为例,我们知道在计算机中,加法器实现最简单,所以所有运算最终都要转为加法运算,因此5-3就要转化为加法:

 # 按以上理论,减一个数等于加上它的补数,所以
 5 - 3
 # 等价于 
 5 + (16 - 3)   // 算术运算单元将减法转化为加法
 # 用二进制表示则为:
 0101 + (10000 - 0011)
 # 等价于
 0101 + ((1 + 1111) - 0011)
 # 等价于
 0101 + (1 + (1111 - 0011))
 # 等价于
 0101 + (1 + 1100) // 括号内是3(0011)的反码+1,正是补码的定义
 # 等价于
 0101 + 1101
 # 所以从这里可以得到
 -3 = 1101
 # 即 -3 在计算机中的二进制表示为  1101,正是 -3 的绝对值 3(0011)的补码(1101)。
 # 最后一步 0101 + 1101 等于
 10010

因为我们的计算机是 4 位的,第一位**“溢出”**了,所以我们只保存了 4 位,即 0010,而当计算机去读取时这正是我们所期望的 2!!!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值