javascript中负数算术右移、逻辑右移的奥秘探索


Posted in Javascript onOctober 17, 2013

javascript中负数的算术右移和逻辑右移都十分的让人迷惑,特别是逻辑右移>>>,你会发现即使一个很小的负数,右移之后,也会得到一个无比巨大的数,这是为什么呢?

原来在逻辑右移中符号位会随着整体一起往右移动,这样就是相当于无符号数的移动了,最后得到的就是一个正数,因为符号位不存在了。首先逻辑右移产生的一定是32位的数,然后负数的符号位为1,这意味着从第32位到符号位的位置全部由1填充,这样的数能不大吗例如-1,逻辑右移0位表现形式就是1111 1111 1111 1111 1111 1111 1111 1111 ,这样的数是当作正数来对待的!所以将-1逻辑右移N位,最后的结果都是全为1!

左移运算保留数字的符号位。例如,如果把 -2 左移 5 位,得到的是 -64,而不是 64。“符号仍然存储在第 32 位中吗?”是的,不过这在 ECMAScript 后台进行,开发者不能直接访问第 32 个数位。即使输出二进制字符串形式的负数,显示的也是负号形式(例如,-2 将显示 -10。)

有符号右移运算

有符号右移运算符由两个大于号表示(<$lt;)。它把 32 位数字中的所有数位整体右移,同时保留该数的符号(正号或负号)。有符号右移运算符恰好与左移运算相反。例如,把 64 右移 5 位,将变为 2:

var iOld = 64; //等于二进制 1000000
var iNew = iOld >> 5; //等于二进制 10 十进制 2同样,移动数位后会造成空位。这次,空位位于数字的左侧,但位于符号位之后。ECMAScript 用符号位的值填充这些空位,创建完整的数字,如下图所示:

无符号右移运算

无符号右移运算符由三个大于号(>>>)表示,它将无符号 32 位数的所有数位整体右移。对于正数,无符号右移运算的结果与有符号右移运算一样。

用有符号右移运算中的例子,把 64 右移 5 位,将变为 2:

无符号右移运算用 0 填充所有空位。对于正数,这与有符号右移运算的操作一样,而负数则被作为正数来处理。

由于无符号右移运算的结果是一个 32 位的正数,所以负数的无符号右移运算得到的总是一个非常大的数字。例如,如果把 -64 右移 5 位,将得到 134217726。如果得到这种结果的呢?

要实现这一点,需要把这个数字转换成无符号的等价形式(尽管该数字本身还是有符号的),可以通过以下代码获得这种形式:

var iUnsigned64 = -64 >>> 0;

然后,用 Number 类型的 toString() 获取它的真正的位表示,采用的基为 2:代码如下:

alert(iUnsigned64.toString(2));

这将生成 11111111111111111111111111000000,即有符号整数 -64 的二进制补码表示,不过它等于无符号整数 4294967232。

出于这种原因,使用无符号右移运算符要小心。

现在来说一下负数的算术右移>>:

我们发现-9>>2=-3,为什么是-3呢?

首先符号位是不变的,不参加右移,然后在9右移的过程中,最低位为1的话,那么右移之后最低位仍然为1!这是很奇怪的。

Javascript 相关文章推荐
javascript ready和load事件的区别示例介绍
Aug 30 Javascript
jQuery中find()方法用法实例
Jan 07 Javascript
在Node.js应用中使用Redis的方法简介
Jun 24 Javascript
Javascript中判断一个值是否为undefined的方法详解
Sep 28 Javascript
javascript实现一个网页加载进度loading
Jan 04 Javascript
javascript 删除数组元素和清空数组的简单方法
Feb 24 Javascript
基于JavaScript实现的希尔排序算法分析
Apr 14 Javascript
JS去掉字符串末尾的标点符号及删除最后一个字符的方法
Oct 24 Javascript
vue双向数据绑定知识点总结
Apr 18 Javascript
javascript实现超好看的3D烟花特效
Jan 01 Javascript
JavaScript实现模态对话框实例
Jan 13 Javascript
vue实现从外部修改组件内部的变量的值
Jul 30 Javascript
jquery快捷动态绑定键盘事件的操作函数代码
Oct 17 #Javascript
js实现的常用的左侧导航效果
Oct 17 #Javascript
给超链接添加特效鼠标移动展示提示信息且随鼠标移动
Oct 17 #Javascript
JS对HTML标签select的获取、添加、删除操作
Oct 17 #Javascript
JS操作数据库的实例代码
Oct 17 #Javascript
JavaScript调用后台的三种方法实例
Oct 17 #Javascript
9行javascript代码获取QQ群成员具体实现
Oct 16 #Javascript
You might like
PHP4中实现动态代理
2006/10/09 PHP
图书管理程序(一)
2006/10/09 PHP
PHP 图像尺寸调整代码
2010/05/26 PHP
解析php中的fopen()函数用打开文件模式说明
2013/06/20 PHP
PHP自定session保存路径及删除、注销与写入的方法
2014/11/18 PHP
php正则替换处理HTML页面的方法
2015/06/17 PHP
ThinkPHP中html:list标签用法分析
2016/01/09 PHP
php将字符串转换为数组实例讲解
2020/05/05 PHP
jquery获取元素值的方法(常见的表单元素)
2013/11/15 Javascript
PHP+jQuery+Ajax实现多图片上传效果
2015/03/14 Javascript
JavaScript使用Replace进行字符串替换的方法
2015/04/14 Javascript
jQuery模拟黑客帝国矩阵效果实例
2015/06/28 Javascript
node.js从数据库获取数据
2016/05/08 Javascript
JavaScript定时器制作弹窗小广告
2017/02/05 Javascript
react中使用swiper的具体方法
2018/05/15 Javascript
详解在vue-test-utils中mock全局对象
2018/11/07 Javascript
Python中关于字符串对象的一些基础知识
2015/04/08 Python
Python素数检测实例分析
2015/06/15 Python
Python在图片中添加文字的两种方法
2017/04/29 Python
python3实现随机数
2018/06/25 Python
Python使用正则表达式分割字符串的实现方法
2019/07/16 Python
python3中numpy函数tile的用法详解
2019/12/04 Python
pip安装tensorflow的坑的解决
2020/04/19 Python
Jupyter Notebook 实现正常显示中文和负号
2020/04/24 Python
Python如何给函数库增加日志功能
2020/08/04 Python
美国求婚钻戒网站:Super Jeweler
2016/08/27 全球购物
德国EGOIST网店:销售畅销的设计师品牌
2017/04/18 全球购物
ALEX AND ANI:手镯,项链,耳环和更多
2017/04/20 全球购物
Zadig&Voltaire官网:法国时装品牌
2018/01/05 全球购物
市场营销职业生涯规划书范文
2014/01/12 职场文书
环保倡议书格式范文
2014/05/14 职场文书
高中生第一学年自我鉴定2015
2014/09/28 职场文书
承诺函格式模板
2015/01/21 职场文书
P站美图推荐——变身女主角特辑
2022/03/20 日漫
电脑开机弹出documents文件夹怎么回事?弹出documents文件夹解决方法
2022/04/08 数码科技
Python开发五子棋小游戏
2022/04/28 Python