码迷,mamicode.com
首页 > 其他好文 > 详细

如何计算位运算中的左移和右移

时间:2020-06-24 11:52:40      阅读:312      评论:0      收藏:0      [点我收藏+]

标签:das   计算   要求   str   原码   符号位   需要   形式   符号   

正数的左移和右移
以3为例
3的二进制为
00000011
右移2位的时候将最右的11去掉左边补00结果为:00000000 — >十进是中的0
左移2位的时候将最左的00去掉右边补00结果为:00001100 —–>十进是中的12

对于-3来说,负数的都是以补码的形式存在于计算器中
补码 = 反码+1
-3的二进制为
100000011
取反的补码为(符号为不变)
111111100
再加1,为补码11111101

右移2位的时候将最右的01去掉左边补11结果为:11111111 —> 为补码,要求原码
还需要-1 :11111110 ,再取反(符号位不动) :10000001:——>十进制中的-1,所以-3的右移2位为十进制中的-1

左移2位的时候将最左边11去掉右边补00结果为:11110100 —-> 为补码,要求原码

如何计算位运算中的左移和右移

标签:das   计算   要求   str   原码   符号位   需要   形式   符号   

原文地址:https://www.cnblogs.com/zaochajun/p/13186579.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!