一、概念

  位运算在数字底层(表示数字的32个数位)进行运算的。由于位运算是低级的运算操作,所以速度往往也是最快的,但是它很不直观,许多场合不能够使用。大多数语言都提供了按位运算符,恰当的使用按位运算符有时候会取得很好的效果。

  位运算只对整数起作用,如果一个运算不是整数,会自动转为整数后再运行。虽然在Javascript内部,数值都是以64位浮点数的形式储存,但是做位运算的时候,是以32位带符号的整数进行运算的,并且返回值也是一个32位带符号的整数。

  这种位转换使得在对特殊的NaN和infinity值应用位操作时,这两个值会被当成0来处理。如果是对非数值应用位操作符时,会先使用Number()方法将值转换成数值再应用位操作,得到的结果是一个数值。

  二进制:ECMAScript整数有两种类型,即有符号整数(允许用正数和负数)和无符号整数(只允许用正数)。在 ECMAScript 中,所有整数字面量默认都是有符号整数。

  有符号整数使用 31 位表示整数的数值,用第 32 位表示整数的符号,0 表示正数,1 表示负数。数值范围从 -2147483648 到 2147483647。表示符号的位叫做符号位,符号位的值决定了其它位数值的格式。其中,正数以纯二进制格式存储,31位中的每一位都表示2的幂,第一位(叫做位0)表示2的1次以此类推,没有用到的位以0填充,可忽略不计。

  如:数10的表示法

    

     10的二进制是‘1010’.它只用了前4位,这4位是数字的有效位。其它的数位可以忽略不计。

     console.log((10).toString(2)); //1010

    反推的话:

    

    负数可以存储为二进制代码,不过采用的形式是二进制补码,计算数字二进制补码的步骤如下:

    1、确定数字的非负版本的二进制表示

    2、求得二进制反码后要把0替换为1,1替换为0

    3、在二进制反码上加1

    如:确定-10的二进制补码

      1、10的二进制表示如下:0000 0000 0000 0000 0000 0000 0000 1010

    2、把0替换1,1替换0: 1111 1111 1111 1111 1111 1111 1111 0101

    3、在二进制反码上加1

    

     所以-10的二进制表示是1111 1111 1111 1111 1111 1111 0110.需要注意的一点是在处理有符号的整数时不能访问31位。但是,把负整数转换成二进制字符串后,ECMAScript并不以二进制补码的形式显示,而是用数字绝对值的标准二进制代码前面加负号的形式输出,这是为了避免访问位31位,为了方便 。

    例子如下:console.log((-10).toString(2)); //-1010

    位运算符可以进行7种运算,包括位非(NOT),按位与(AND),按位或(OR),按位异或(XOR),左移,有符号右移,无符号右移。

二、具体分析

  1、按位非(NOT)

    按位非操作符由一个波浪线(~)表示,操作它可以返回数值的反码,其本质是操作数的负值减1.对一个整数两次按位非得到它的自身, 对于小数两次按位非可以得到取整的效果。

  1. <script>
  2. var n = 9;
  3. var i = 9.9;
  4. var m = ~n;
  5. console.log(m); //-10
  6. console.log(~~n);//9
  7. console.log(~~i);//9
  8. </script>

  2、按位与(AND)

    按位与操作符由一个和符号(&)表示,它有两个操作数。直接对数字的二进制形式进行运算。它把每个数字中的数位对齐,然后用下面的规则对同一位置上的两个数位进行AND运算。按位与操作只有在两个数值的对应位都是1时才返回1,任何一位是0结果都是为0.

    

  1. <script>
  2. var n = 10;
  3. var m = 15;
  4. console.log(n & m); //10
  5. console.log(n.toString(2), m.toString(2)); //1010 1111
  6. </script>

  分析如下:

    

  3、按位或(OR)

     按位或操作符由一个竖线符号(|)表示,同样也有两个操作符,按位或操作按照下表来进行。按位或操作在有一个位是1的情况下就返回1,而只有在两个位数都是0的情况下才返回0.一个整数与0按位或运算可以得到它本身,一个小数与0按位或者运算可以得到取整的效果。

    

  1. <script>
  2. var n = 10;
  3. var m = 15;
  4. console.log(n | m); //15
  5. console.log(3.9 | 0); //3
  6. console.log(4.1 | 0); //4
  7. console.log(n.toString(2), m.toString(2)); //1010 1111
  8. </script>

    分析如下:

    

   4、按位异或(XOR)

     它由一个插入符号(^)表示,也需要两个操作数,以下是真值表。按位异或的两个数值相同时返回0,不同时返回1。一个整数与0按位异或可以保持自身,一个小数与0按位异或可以取整。

    

  1. <script>
  2. var n = 10;
  3. var m = 15;
  4. console.log(n ^ m); //5
  5. console.log(n.toString(2), m.toString(2)); //1010 1111
  6. </script>

    分析如下:

    

    ^有一个特殊运用,连续对两个数a和b进行三次异或运算,a^=b,b^=a,a^=b可以互换它们的值。这意味着,使用^可以在不引入临时变量的前提下,互换两个变量的值。

  1. <script>
  2. var a = 10, b = 11;
  3. a ^= b, b ^= a, a ^= b;
  4. console.log(a, b); //11 10
  5. </script>

  5、左移

     左移操作符由两上小于号(<<)表示,这个操作符会把数值的所有位向左移动指定的位数。

     如:将数值3(二进制为11)向左移动5位,结果就是96

  1. <script>
  2. var n=3;
  3. var m=n<<5;
  4. console.log(n.toString(2)); //11
  5. console.log(m); //96
  6. </script>

    分析如下:

    

  6、有符号右移

      由两个大于号(>>)表示,将数值向右移动,但保留符号位。在符号的右移操作与左移操作正好相反,如果96向右移动5位变成3。

  1. <script>
  2. var n = 96;
  3. console.log(n >> 5);//3
  4. </script>

  7、无符号右移

      它是由三个大于号来表示(>>>),这个操作符会将数值的所有32位都向右移动,对于正数来说,无符号右移的结果和有符号右移的结果相同。但对于负数来说,无符号右移是以0来填充空位而不是像有符号那样以符号位的值来填充空位。还有一点是,无符号右移操作符会把负数的二进制码当成正数的二进制码且由于负数以其绝对值的二进制补码形式表示,所以会导致无符号右移后的结果非常的大。

      如:-96无符号右移5

  1. <script>
  2. var n = -96;
  3. console.log(n >>> 5);//134217725
  4. </script>

    分析:

    

三、常见的运用

   利用<<来实现乘法运算;利用>>实现除法运算;利用^来实现值互换;小数取整

  1. <script>
  2. console.log(4 << 1);//8
  3. console.log(4 << 2);//16
  4. console.log(4 << 3);//32
  5. console.log(4 << 4);//64
  6. console.log(4 << 5);//128
  7. console.log(4 << 6);//256
  8.  
  9. console.log(5 >> 3);//0
  10. console.log(14 >> 2);//3
  11. console.log(225 >> 5);//7
  12.  
  13. var a = 20, b = 4;
  14. a ^= b, b ^= a, a ^= b;
  15. console.log(a, b);//4 20
  16.  
  17. console.log(~~9.9);//9
  18. console.log(9.8 | 0);//9
  19. console.log(9.7 ^ 0);//9
  20. console.log(9.6 << 0);//9
  21. console.log(9.3 >> 0);//9
  22. </script>

js之运算符(位运算符)的更多相关文章

  1. PHP中的运算符---位运算符、递增递减运算符、三元运算符、字符串运算符、数组运算符、类型运算符、错误控制运算符

    1.位运算符 位运算符用来对整型数的指定位进行置位,如果被操作数是字符串,则对该字符串的ASCII码值进行操作. 运算类型 运算符 举例 结果 按位与 & $a & $b 将$a 与 ...

  2. javascript运算符——位运算符

    × 目录 [1]二进制 [2]非 [3]与[4]或[5]异或[6]左移[7]右移[8]>>>[9]应用 前面的话 位运算符是非常底层的运算,由于其很不直观,所以并不常用.但是,其速度 ...

  3. java入门---运算符&算术运算符&自增自减运算符&关系运算符&位运算符

        计算机的最基本用途之一就是执行数学运算,作为一门计算机语言,Java也提供了一套丰富的运算符来操纵变量.我们可以把运算符分成以下几组: 算术运算符 关系运算符 位运算符 逻辑运算符 赋值运算符 ...

  4. Golang的运算符-位运算符

    Golang的运算符-位运算符 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.位运算符概述 常见的位逻辑运算符: &: 位与运算符,表示AND(表示所有条件都得匹配), ...

  5. js中的位运算符 ,按位操作符

    按位操作符(Bitwise operators) 将其操作数(operands)当作32位的比特序列(由0和1组成),而不是十进制.十六进制或八进制数值.例如,十进制数9,用二进制表示则为1001.按 ...

  6. 【Python】2.16学习笔记 运算符,位运算符,if-else语句

    复合运算符 a *= b # a = a * b a += b # a = a + b a -= b # a = a - b ... 位运算符 对数字进行二进制运算 按位与 &,二进制位都为一 ...

  7. 【java从入门到精通】day-07-逻辑运算符-位运算符-条件运算符-扩展赋值运算符

    逻辑与(&&).或(||).非(!) 示例: package operator;​public class Demo05 {    public static void main(St ...

  8. 位运算符 & | ~ ^ << >>

    # ### 位运算符 & | ~ ^ << >> var1 = 19 var2 = 15 # & 按位与 """ res = va ...

  9. PHP 位运算符

    位运算符 位运算符是指对二进制位从低位到高位对齐后进行运算. 符号 作用 举例 个人理解 & 按位与 $m & $n 全1为1,否则为0 | 按位或 $m | $n 全0为0,有1为1 ...

  10. C语言的各种位运算符的操作简述

    运算符: 算术运算符: + , - , * , / , % , ++ , -- 符合运算符: += , *= , /= , %= 条件运算符:  ? : 关系运算符: == , >= , < ...

随机推荐

  1. vmware安装centos虚拟机,没有ip地址

    如果centos没有ip地址,就不能通过xshell等工具进行连接,且在上面部署的项目,外部也不能正常访问 两种方式可以解决 第一种,在安装的时候,在INSTALLATION SUMMARY界面的SY ...

  2. 判断List是否为空的问题

    今天公司安排给页面调试Bug,感觉公司人员写的判断判断List是否为空存在一定的问题,公司判断是list!=null这是完全不对的,这只会判断是否有list对象.如果为空,他也会执行if(list!= ...

  3. SQL Server 数据库设计、命名、编码规范

    https://blog.csdn.net/songguozhi/article/details/5858159 SQL Server 数据库设计.命名.编码规范

  4. leetcode334 递增的三元子序列

    class Solution { public: bool increasingTriplet(vector<int>& nums) { //使用双指针: int len=nums ...

  5. LC 431. Encode N-ary Tree to Binary Tree 【lock,hard】

    Design an algorithm to encode an N-ary tree into a binary tree and decode the binary tree to get the ...

  6. 【React自制全家桶】三、React使用ref操作DOM与setState遇到的问题

    在React中同时使用ref操作DOM与setState常常会遇到 比如操作的DOM是setState更新之前的DOM内容,与想要的操作不一致.导致这样的原因是setState函数是异步函数. 就是当 ...

  7. RN在Mac环境下开发环境搭建

    1.推荐使用Homebrew来安装 Node 和 Watchman.在命令行中执行下列命令安装: brew install node brew install watchman 如果你已经安装了 No ...

  8. ControlTemplate in WPF —— Calendar

    <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" x ...

  9. python programming作业10(仍有一点点小bug)

    # -*- coding: utf-8 -*- import os import platform import sys from PyQt5.QtCore import * from PyQt5.Q ...

  10. Node、Document关系的探究

    上图来自于<JavaScript权威指南(第六版)>P375 受到上图的启发,写了如下测试代码: var head = document.getElementsByTagName(&quo ...