计算机最基本的操作单元是字节(byte),一个字节由8个位(bit)组成,一个位只能存储一个0或1,其实也就是高低电平。无论多么复杂的逻辑、庞大的数据、酷炫的界面,最终体现在计算机最底层都只是对0101的存储和运算.
1. 加法运算
加法运算:将一个整数用二进制表示,其加法运算就是:相异(^)时,本位为1,进位为0;同为1时本位为0,进位为1;同为0时,本位进位均为0.
所以,不计进位的和为sum = a^b,进位就是arr = a&b,(与sum相加时先左移一位,因为这是进位)。
1 | /* |
2. 减法运算
减法运算:a-b = a+(-b) 根据补码的特性,各位取反加1即可(注意得到的是相反数,不是该数的补码,因为符号位改变了)
1 | //首先取减数的补码,然后相加 |
3. 乘法运算
乘法运算:将b个a相加。
1 | function multiply($a, $b) { |
4. 除法运算
除法运算:计算a最多能减去多少个b。
1 | function divide($a, $b) { |
补充:
计算机系统中,数值一律用补码来表示:因为补码可以使符号位和数值位统一处理,同时可以使减法按照加法来处理。
补码简单介绍:数值编码分为原码,反码,补码,符号位均为0正1负。
- 原码 -> 补码:数值位取反加1
- 补码 -> 原码:对该补码的数值位继续 取反加1
- 补码 的绝对值(称为真值):正数的真值就是本身,负数的真值是各位(包括符号位)取反加1(即变成原码并把符号位取反)
- b -> -b :各位(包括符号位)取反加1