求问,计算机如何借助补码将加减乘除运算统一转变为加法运算。求解,求解,求解
众所周知,计算机底层都是二进制的,所有的加减乘除都会被转为二进制再进行计算
例如: 5 + 7 = 12
0 0 0 0 0 1 0 1
+ 0 0 0 0 0 1 1 1
-----------------------
0 0 0 0 1 1 0 0 = 12
例如: 5 - 7 = 5 + (-7) = -2
0 0 0 0 0 1 0 1
+ 1 1 1 1 1 0 0 1
-----------------------
1 1 1 1 1 1 1 0 = -2
例如: 5 * 7 = 5 << 3 + 5 = 35
// 先向左位移
0 0 0 1 1 1 1 0
// 再相加
0 0 0 1 1 1 1 0
+ 0 0 0 0 0 1 0 1
-----------------------
0 0 1 0 0 0 1 1 = 35
此外,你可以看看我的这篇文章:http://t.csdn.cn/94Ekm
相信你对原码、反码和补码的理解会更深刻
Tips
- 一个数乘以
2
相当于把这个数的二进制形式向左移动一位,除以2
则相当于向右移动一位。- 计算机在底层进行运算的时候,无论是正数还是负数,一律使用其补码进行计算