标签:识别 数据 并且 机器 保留 code 探索 操作 因此
1)
假如用两个字节表示 一个整数, 如下:
十进制数字1 的二进制表现形式: 0000 0000 0000 0001
十进制数字2 的二进制表现形式: 0000 0000 0000 0010
如何表示二进制数的正负?
规则:把二进制数中的最高位(最左边的那位)用作符号位
对于有符号数,最高位被计算机系统规定为符号位(0为正,1为负)
对于无符号数,最高位被计算机系统规定为数据位
按照这种说法,比如有符号数 +2 -2 的原码形式:
+2 = 0000 0000 0000 0010
-2 = 1000 0000 0000 0010
真值 机器数
+1 = 0000 0000 0000 0001
-1 = 1000 0000 0000 0001
-----------------------------------------
1000 0000 0000 0010
-1+1 的结果?
-1+1 = 1000 0000 0000 0010 ----》 -2
不等于0,按理说-1+1等于0才对,为什么会是-2呢?
数字在计算机中,是用二进制补码的形式来保存的,因此-1 +1需要按照补码进行相加才是正确的结果
规则:
正数:原码 = 反码 = 补码
负数:反码 = 符号位不变,其他位取反
补码 = 反码+1
1 的原码:0000 0000 0000 0001
-1的原码:1000 0000 0000 0001
-1的反码:1111 1111 1111 1110
-1的补码:1111 1111 1111 1111
重新计算 -1+1 结果
1111 1111 1111 1111
0000 0000 0000 0001
---------------------------
0000 0000 0000 0000
负数补码转换原码的规则:
原码 = 补码的符号位不变 -->数据位取反--> 尾+1
-1的补码:1111 1111 1111 1111
取反:1000 0000 0000 0000
-1的原码:1000 0000 0000 0001
可以把减法用加法来算,只需设计加法器就好了。运算的时候都是用补码去运算的。 2-1 = 2+(-1)=0000 0000 0000 0010 +1111 1111 1111 1111
为何要使用原码, 反码和补码 既然原码才是被人脑直接识别并用于计算表示方式, 为何还会有反码和补码呢? 首先, 因为人脑可以知道第一位是符号位, 在计算的时候我们会根据符号位, 选择对应加减,但是对于计算机,加减乘数已经是最基础的运算, 要设计的尽量简单。计算机辨别"符号位"显然会让计算机的基础电路设计变得十分复杂!于是人们想出了将符号位也参与运算的方法. 我们知道,根据运算法则减去一个正数等于加上一个负数, 即: 1-1 = 1 + (-1) = 0 , 所以机器可以只有加法而没有减法, 这样计算机运算的设计就更简单了.于是人们开始探索 将符号位参与运算, 并且只保留加法的方法
#10进制转为2进制 >>> bin(10) ‘0b1010‘ #2进制转为10进制 >>> int("1001",2) 9 #10进制转为16进制 >>> hex(10) ‘0xa‘ #16进制到10进制 >>> int(‘ff‘, 16) 255 >>> int(‘0xab‘, 16) 171 #16进制到2进制 >>> bin(0xa) ‘0b1010‘ >>> #10进制到8进制 >>> oct(8) ‘010‘ #2进制到16进制 >>> hex(0b1001) ‘0x9‘
<1>位运算的介绍 & 按位与 | 按位或 ^ 按位异或 ~ 按位取反 << 按位左移 >> 按位右移
用途: 直接操作二进制,省内存,效率高
### 乘法 移动1位 *2 In [55]: 5 << 1 Out[55]: 10 In [56]: a = 5 In [57]: a = a<<1 In [58]: a Out[58]: 10 In [59]: a = a*2 In [60]: a Out[60]: 20 ###除法 移动1位 *2 In [61]: 8>>1 Out[61]: 4 In [62]: 8>>2 Out[62]: 2
【为什么9取反变成了-10的说明】:
9的原码 ==> 0000 1001 因为正数的原码=反码=补码,所以在 真正存储的时候就是0000 1001 接下来进行对9的补码进行取反操作 进行取反==> 1111 0110 这就是对9 进行了取反之后的补码 既然已经知道了补码,那么接下来只要转换为 咱们人能识别的码型就可以,因此按照规则 ,把这个1111 0110 这个补码 转换为原码即可 符号位不变,其它位取反==> 1000 1001 然后+1 ,得到原码 =======>1000 1010 这就是 -10
标签:识别 数据 并且 机器 保留 code 探索 操作 因此
原文地址:http://www.cnblogs.com/venicid/p/7922704.html