我是靠谱客的博主 激情金毛,最近开发中收集的这篇文章主要介绍位运算中的左移和右移的计算详解,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

最近在学习javaScrapt,在学到位运算符这部分的时候,突然发现看不懂书上的例子了。经过查找资料后,发现了一遍不错的文章。分享一下:
正数的左移和右移
以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 —-> 为补码,要求原码
还需要-1:11110011,再取反(符号位不动):10001100:—–>十进制中的-12,所以-3的左移2位为十进制中的-12

最后

以上就是激情金毛为你收集整理的位运算中的左移和右移的计算详解的全部内容,希望文章能够帮你解决位运算中的左移和右移的计算详解所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(49)

评论列表共有 0 条评论

立即
投稿
返回
顶部