首页 > 其他 > 详细

计算机的运算方式

时间:2016-01-14 09:48:02      阅读:124      评论:0      收藏:0      [点我收藏+]

原码 反码 补码

以下案例均为32位操作系统案例 64位操作系统道理也是一样的 无非位数更多 可运算的数值更大 


我们定义最左边的一位为符号位 正数的符号位为负数的符号位为1

正数的反码补码均为其本身 

负数的反码为除去符号位所有位的取反运算

负数的补码为其反码+1



 

32

原码:

00000000 00000000 00000000 00100000 

反码:

00000000 00000000 00000000 00100000 

补码:

00000000 00000000 00000000 00100000

 

 

17

原码

00000000 00000000 00000000 00010001

反码

00000000 00000000 00000000 00010001

补码

00000000 00000000 00000000 00010001

 

-17

原码

10000000 00000000 00000000 00010001

反码

11111111 11111111 11111111 11101110

补码

11111111 11111111 11111111 11101111

 

 

运算 32+17 =49

cpu2进制运算 均为补码运算  

32的补码   00000000 00000000 00000000 00100000

17的补码   00000000 00000000 00000000 00010001

        +

——————————————————————————————————————————————————

           00000000 00000000 00000000 00110001

其结果为 110001=25+24+20=49  运算正确


运算32-17=15  cpu的运算为32+-17=15

32的补码   00000000 00000000 00000000 00100000

-17的补码  11111111 11111111 11111111 11101111

        +

——————————————————————————————————————————————————

           00000000 00000000 00000000 00001111

最左边的那个符号位被挤掉了 其运算结果为

1111=23+22+21+20=8+4+2+1=12+3=15 与运算结果吻合

 

 这就是计算机的运算方式

 

计算机的运算方式

原文:http://www.cnblogs.com/chengfeifei/p/5129194.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!