奇技淫巧:指过于奇巧而无益还让人着迷的技艺与制品。

And(与) &
Or(或) |
Exclusive Or(异或)

或者称 Xor

^
Not(非) ~

位运算符,我们在日常js开发中其实 说真的,很少会用到,甚至可以说 有相当一部分的 javascripter完全不知道 位运算符

但是我们日常中肯定常常会用到 '&&'、'||'、'!' 这么几个符号,它们看起来跟位运算符很像,但是 它们并不是位运算符,它们只运用在 ‘boolean 布尔值’运算中

曾几何时我曾疑惑过 为什么 我们 在 js中 做条件判断的时候 ‘and’是用‘&&’而不是‘&

现在答案来了,因为‘&’已被占用,是个位运算符

虽然说 我们日常开发中 很多js原生方法能满足我们了,但是适当掌握一些 位运算 能提高你的开发效率和代码性能

在这里我们不探讨 位运算符的原理,有兴趣的可以自行谷歌


Not ~

Not 实质上  是对数字向下取整求负 再 减1

var num = 20.1          
console.log(~num)    // -21

And &

这个 就有点复杂了

对数字的二进制形式进行运算。它把每个数字中的数位对齐,然后用下面的规则对同一位置上的两个数位进行 AND 运算:

第一个数字中的数位 第二个数字中的数位 结果
1 1 1
1 0 0
0 1 0
0 0 0

举例: 30 & 3

我们先来看下两个数的 二进制

var i = 30
i.toString(2) // 11110
var j = 3
j.toString(2) // 11
console.log(i & j) // 2

为什么是‘2’?

我们来看一下, 按照上表的关系 我们可以得出 下表结果

30 1 1110
3 0 0011
结果 0 0010

二进制 ‘10’ 对应的 十进制数就是 ‘2’了


Or |

or跟and 相似 也是 转为二进制之后 进行的 计算 不过规则不同

第一个数字中的位数 第二个数字中的位数 结果
1 1 1
1 0 1
0 1 1
0 0 0

同样的 我们拿 30 | 3来举例

var i = 30
i.toString(2) // 11110
var j = 3
 j.toString(2) // 11
console.log(i | j) // 31
30 1 1110
3 0 0011
结果 1 1111

Exclusive Or ^(或者称 Xor)

也是类似 or 和 and 一样 不过规则不同

第一数字中的位数 第二数字中的位数 结果
1 1 0
1 0 1
0 1 1
0 0 0
var i = 30
i.toString(2) // 11110
var j = 3
 j.toString(2) // 11
console.log(i ^ j) // 29
30 1 1110
3 0 0011
结果 1 1101

那么 看了这4个 基本运算之后,

究竟我们的 奇技淫巧在哪呢?

我们再回到 Not 运算符上,可以说 And Or Xor 这三个位运算 我们用到的可能性比较小

但是 Not 的 法则 是 向下取整 后 求负 减1

注意我 着重标出的 关键字,是不是想到了什么?没错 Math.floor()

如果说 单次 使用 Not 是 求负减1 那么 我连续使用 2次 Not 会怎么样呢?对于 整型 的数字来说 连续两次 就是它本身,那么对于浮点型的数字呢? 那岂不就是 他的向下取整了么?

为了验证 我们可以试一下

var i = 25.1
console.log(~~i) //25

但是又有人说 向下取整 不是有 Math.floor() 方法么?

好了 这就是我们奇技淫巧了 为什么要用 两次 Not 而不用 Math.floor()

第一,你不觉得 ‘~~’ 输入起来 比 'Math.floor()' 快么?

第二,就是 '~~' 比 'Math.floor()' 更快。

Math.floor() 运行速度 是 3.5 millions ops/sec

~~的运行速度是 3.8 millions ops/sec

但是 ~~ 只适用于 32位 以下的整型,对于 超过32位的 整型 还是要用 Math.floor()

javascript奇技淫巧之位运算符的更多相关文章

  1. Javascript中的位运算符和技巧

    ECMAScript 整数有两种类型,即有符号整数(允许用正数和负数)和无符号整数(只允许用正数).在 ECMAScript 中,所有整数字面量默认都是有符号整数,这意味着什么呢? 有符号整数使用 3 ...

  2. js 位运算符

    MDN定义:位运算符将它的操作数视为32位元的二进制串(0和1组成)而非十进制八进制或十六进制数. 例如:十进制数字9用二进制表示为1001,位运算符就是在这个二进制表示上执行运算,但是返回结果是标准 ...

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

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

  4. javascript运算符——位运算符

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

  5. JavaScript位运算符 2

    按位运算符是把操作数看作一系列单独的位,而不是一个数字值.所以在这之前,不得不提到什么是“位”: 数值或字符在内存内都是被存储为0和 1的序列,每个0和1被称之为1个位,比如说10进制数据2在计算机内 ...

  6. JavaScript按位运算符~

    1. JavaScript按位运算符 Bit operators work on 32 bits numbers. 2. JavaScript按位运算符~ 值得注意的是,在JavaScript中,~5 ...

  7. JavaScript位运算符

    位运算符是在数字底层(即表示数字的 32 个数位)进行操作的. 重温整数 ECMAScript 整数有两种类型,即有符号整数(允许用正数和负数)和无符号整数(只允许用正数).在 ECMAScript ...

  8. javascript的变态位运算

    javascript的变态位运算 var a = "10" | 0; alert(a); alert (typeof a);结果为10,number. 这就是说这条语句可以将字符串 ...

  9. JavaScript奇技淫巧45招

    JavaScript奇技淫巧45招 撰写于 2015年1月5日 修改于 2016年6月16日 分类 翻译 标签 JavaScript 本文是一篇翻译文章,原文信息如下: 原文:45 Useful Ja ...

随机推荐

  1. 【优化】COUNT(1)、COUNT(*)、COUNT(常量)、COUNT(主键)、COUNT(ROWID)等

    http://blog.itpub.net/26736162/viewspace-2136339/

  2. linux内核数据包转发流程(二):中断

    [版权声明:转载请保留出处:blog.csdn.net/gentleliu.邮箱:shallnew*163.com] 内核在处理2层数据包之前,必须先处理中断系统.设立中断系统,才有可能每秒处理成千的 ...

  3. TCP套接字端口复用SO_REUSEADDR

    下面建立的套接字都是tcp套接字 1.进程创建监听套接字socket1,邦定一个指定端口,并接受了若干连接.那么进程创建另外一个套接口socket2,并试图邦定同一个端口时候,bind错误返回“Add ...

  4. TextAppearance.Material.Widget.Button.Inverse,Widget.Material.Button.Colored

    编译xamarin android项目报错: android:TextAppearance.Material.Widget.Button.Inverse android:Widget.Material ...

  5. Android 数据存储02之文件读写

    Android文件读写 版本 修改内容 日期 修改人 V1.0 原始版本 2013/2/25 skywang Android文件读写的有两种方式.一种,是通过标准的JavaIO库去读写.另一种,是通过 ...

  6. Linux init 0-6 启动级别

    原文地址:http://blog.sina.com.cn/s/blog_5f8e8d9801010wlr.html 原文地址:[转]Linux init 0-6 启动级别作者:流水清风 init 0- ...

  7. EXCEL密码破解/破解工作表保护密码

    网上有很多这个代码,但很多朋友并不太了解如何运用在此做了一些整理,希望对大家有所帮助! 注:很多时候会因为忘记密码丢失重要EXCEL文件而烦恼,这份代码就能帮你找回,仅仅出之这个初衷,如因为这个代码让 ...

  8. Asp.Net MVC3.0项目部署到Win7 64过程总结

    前言 之前一直是通过Visual Studio直接F5来运行自己编写的项目或者小程序,很少通过部署发布到IIS上面,于是自己便在自己的笔记本上进行测试,结果还真是发现了不少问题,于是自己重新通过虚机程 ...

  9. Gradle 简介

    一.简介 Gradle 是 Android 现在主流的编译工具,虽然在Gradle 出现之前和之后都有对应更快的编译工具出现,但是 Gradle 的优势就在于它是亲儿子,Gradle 确实比较慢,这和 ...

  10. .Net-using-Class:MemoryCache 类

    ylbtech-.Net-using-Class:MemoryCache 类 初始化 System.Runtime.Caching.MemoryCache 类的新实例. 1. 程序集 System.R ...