javascript操作符(~、&、|、^、>>、<<)

1、操作符非(~)

  var num = 7;

  var num2 = ~num;

  alert(num2);    // -8

  var num3 = -1;

  var num4 = ~num3;

  alert(num4);    // 0

  可以看出:~ 就是将原来的数值加1后取负,  即: ~x = -(x + 1)。

 

  底层原理: 

    先了解一下基本知识

    1、计算机里的数字是以补码的形式表示的。

    2、取反即:0变1,1变0。

    3、第一个数为符号位,0为正数,1为负数。

    4、正数的原码、反码、补码都一样。

    5、负数的反码:符号位不变,其余取反。补码:反码加1。

    6、0的反码补码都为0。

  

 

 

    ~即对当前数取反所表示的值。计算机中数字以补码形式表示,7的取反正好是-8的补码,所以~7 == -8;

 

   用途:

    1)、取整数随机数

      ~~(Math.random()*7);    // 在0~6内取整数随机数,包括0和6

      ~(Math.random()*7);      // 在-7~-1内取整数随机数,包括-7和-1

      -~(Math.random()*7);      // 在1~7内取整数随机数,包括1和7

    2)、解决抽象渗漏

      抽象渗漏:在代码中暴露底层实现的细节。

      对于indexOf判断是否存在,像>-1、!=-1、>=0、<0之类细节就应该屏蔽掉

      那么用~就很好解决了

 

        var str = 'hello World';
      if(~str.indexOf('ell'))
        return true;
      else
        return false;

 

 

2、按位与&

    var num1 = 25 & 7;

    var num2 = 25 & -7;

    var num3 = -25 & 7;

    var num4 = -25 & -7;

    alert(num1);    // 1

    alert(num2);    // 25

    alert(num3);    // 7

    alert(num4);    // -31

    原理:1&1=1、1&0=0、0&1=0、0&0=0。

    根据规则对补码处理:

    25 & 7

    

    25 & -7

    

    -25 & 7

    

    -25 & -7

    

    红 & 红 == 绿    绿 == 最后一行的数的补码

 

3、按位或 | 

    原理:1|1=1、1|0=1、0|1=1、0|0=0。

 

    例子: 参考上面的。

 

 

4、按位异 ^

    原理:1^1=0、1^0=1、0^1=1、0^0=0。

 

    例子: 参考上面的。

 

5、左移 <<   、右移 >>  、无符号右移 >>>

    

    简单记法:(a << b) === Math.ceil(a*(2**b));

         (a >> b) === Math.floor(a/(2**b));

    

 

 

 

 

    

 

posted @ 2017-10-22 18:22  梦珀  阅读(4746)  评论(0编辑  收藏  举报