问题
最近踩了个坑。。。首先,来看个例子吧。
console.log(4000000000 >> 1);
将上面代码在浏览器中运行,你会得到什么结果呢?
知识介绍
按位操作符
按位移动操作符
字节序
简单来说,大端字节序就是32位整数中,高位字节在前,和我们平时的阅读顺序是一致的。
实践
上面的知识有点抽象,看过之后应该手动黑人问号❓
为了简单起见,我们用2^31(16进制表示为8FFF)这个数来进行问题出现的原因。
var num = Math.pow(2, 31);
console.log(num >> 1);
原理分析
按照有符号数在计算机内的表示形式(二进制补码),具体内容可以参考这篇文章。我们可以将移位后的二进制补码转换成原码:
- 对非符号位进行取反,结果为:1000,1111,1111,1111
- 对取反结果加1,结果为:1100,0000,0000,0000
- 由于最高位是符号为,我们得到结果为-Math.pow(2, 30) = -1073741824
换一种思路
32位补码1000,0000,0000,0000,表示的有符号数是:-Math.pow(2,31) = -2147483648, 这个数右移一位(除以2)后,就是-1073741824
超过32bit的数怎么办
粗暴截取低32位,然后按照上述方式进行移动,可以试试下面的代码,应该能进一步理解。
console.log(Math.pow(2,32) >> 1);
console.log((Math.pow(2,32) + Math.pow(2,31)) >> 1);
总结
由于JavaScript本身能表示的整数是比较大的(可以通过Number.MAX_SAFE_INTEGER进行查看),所以反倒显得其右移操作比较奇怪。
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 模板不会安装或需要功能定制以及二次开发?
发表评论
还没有评论,快来抢沙发吧!