js按位运算符及其妙用

大多数语言都提供了按位运算符,恰当的使用按位运算符有时候会取得的很好的效果。html

在我看来按位运算符应该有7个:spa

一、& 按位与

&是二元运算符,它以特定的方式的方式组合操做数中对应的位,若是对应的位都为1,那么结果就是1, 若是任意一个位是0 则结果就是0。code

1 & 3的结果为1htm

那咱们来看看他是怎么运行的ip

1的二进制表示为 0 0 0 0 0 0 1ci

3的二进制表示为 0 0 0 0 0 1 1get

根据 & 的规则 获得的结果为 0 0 0 0 0 0 0 1,十进制表示就是1string

二、| 按位或it

|运算符跟&的区别在于若是对应的位中任一个操做数为1 那么结果就是1。io

1的二进制表示为 0 0 0 0 0 0 1

3的二进制表示为 0 0 0 0 0 1 1

因此 1 | 3的结果为3

三、^ 按位异或

^运算符跟|相似,但有一点不一样的是 若是两个操做位都为1的话,结果产生0。

1的二进制表示为 0 0 0 0 0 0 1

3的二进制表示为 0 0 0 0 0 1 1

因此 1 ^ 3的结果为2

四、~ 按位非

~运算符是对位求反,1变0,0变1,也就是求二进制的反码

1的二进制表示为 0 0 0 0 0 0 1

因此 ~1 的结果是-2

五、>> 右移

>>运算符使指定值的二进制全部位都右移规定的次数,对于其移动规则只需记住符号位不变,左边补上符号位即按二进制形式把全部的数字向右移动对应的位数,低位移出(舍弃),高位的空位补符号位,即正数补零,负数补1。

1的二进制表示为 0 0 0 0 0 0 1

因此 1>>1的结果为0

六、<< 左移

<<运算符使指定值的二进制全部位都左移规定的次数,对于其移动规则只需记住丢弃最高位,0补最低位即按二进制形式把全部的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零。

1的二进制表示为 0 0 0 0 0 0 1

因此 1<<1的结果为2 七、>>> 无符号右移

>>>运算符忽略了符号位扩展,0补最高位,可是只是对32位和64位的值有意义。

位运算符在js中的妙用:

一、使用&运算符判断一个数的奇偶

偶数 & 1 = 0

奇数 & 1 = 1

那么0&1=0,1&1=1

二、使用~~,>>,<<,>>>,|来取整

~~3.14 = 3

3.14 >> 0 = 3

3.14 << 0 = 3 3.14 | 0 = 3 3.14 >>> 0 = 3(>>>不可对负数取整)

注意:~~-3.14 = -3 其它的同样

三、使用<<,>>来计算乘除

乘法:

1*2 = 2

1<>1 = 1(2/2的一次方)

四、利用^来完成比较两个数是否相等

1 ^ 1 = 0

1 ^ 非1数 !=0

因此同一个数……同一个数等于0,不然不等于0

五、使用^来完成值交换

a = 1

b = 2

a ^= b

b ^= a

a ^= b

结果a=2,b=1

六、使用&,>>,|来完成rgb值和16进制颜色值之间的转换

16进制颜色值转RGB:

1
2
3
4
5
6
7
function hexToRGB(hex){
     var hex = hex.replace( "#" , "0x" ),
         r = hex >> 16,
         g = hex >> 8 & 0xff,
         b = hex & 0xff;
     return "rgb(" +r+ "," +g+ "," +b+ ")" ;
}

RGB转16进制颜色值:

1
2
3
4
5
function RGBToHex(rgb){
     var rgbArr = rgb.split(/[^\d]+/),
         color = rgbArr[1]<<16 | rgbArr[2]<<8 | rgbArr[3];
     return "#" +color.toString(16);
}

运行hexToRGB("#ffffff")返回"rgb(255,255,255)"

运行RGBToHex("rgb(255,255,255)")返回"#ffffff"

转载自:http://www.deanhan.cn/js-bitwise-operation.html

相关文章
相关标签/搜索