标签:使用 sp java bs as 工作 算法 nbsp javascript
今天在工作中在 js里看到了 >>> 这么一个东西 不认识 而且也没在其他地方没见到过。
上网查了资料才知道这是一个运算符 叫无符号右位移运算符,名字挺长也很难理解,是跟二进制有关系的。
那既然有向右的了 肯定也有向左的 那就是<<< 。
比如:100 的二进制是 01100100 向右移动两位是00011001 而这个数在转回十进制就是25。
不了解这些之间怎么转换的 可以去百度一下算法 或者直接在网上找个这样的应用,当然这不重要 重要的事我们要知道这个运算符是干什么用的。他就是这么简单 虽然名字看起来很专业 但是就是移动一下位数。
与之类似的还有按位运算符, << 按位左移运算符 和 >> 按位右移运算符。 顾名思义 也就是一个向左移动一个向右移动。他和前面的那个区别是:
按位移运算时如果数字为正数时位移后在前面补0,为负数时则在位移后在前面补1
例
100>>2==25 和上面的计算方法一样
如果100为负数
-100>>>2
-100的二进制为-_-好长。
1111111111111111111111111111111111111111111111111111111111111100
移除最后2位后
11111111111111111111111111111111111111111111111111111111111111
之后在前面补两位
1111111111111111111111111111111111111111111111111111111111111111
变为十进制后结果为-1
所以
-100>>>2=-1。
不过我在使用过程中发现了个小技巧,比如100>>2 ==25,这个我们试过的 ,可以这样理解100除以2的2次方,也就是100/2/2==25, 这是我们初中数学就会得。
那反过来100<<2 也就是100乘以2的2次方 也就是400了。
这样是不是就好理解多了。
以上都是个人理解 肯定有不恰当和错误的地方 欢迎指正!
标签:使用 sp java bs as 工作 算法 nbsp javascript
原文地址:http://www.cnblogs.com/Running-cqw/p/4151307.html