在ECMAScript中,有少数的几个操作符可以对二进制位进行直接操作,这几个操作符本身直接对二进制进行操作,所有它们的本身是非常效率的,学习这一段有助于以后的优化以及理解。 ECMAScript中采用IEEE-754 64位格式存储,但是在开发的过程中不是直接操作的64位,而是后台会先将64位的数据转换位32位,然后让开发者进行操作,最后再填充成64位存储。但是在转换的过程中也会有一个副效应,那就是在对NaN和Infinity的时候,这两个值会被当成0进行处理。对于非数值使用位操作符,会先使用Number()转型函数进行转换为一个数值。 要了解位操作符,首先得来属性一点底层的知识,在计算机中数值分有符号数(如:+40和-40)和无符号数(如:40),这两种数值在二进制里是用不同的表示。

无符号数

无符号数比较好理解,具体怎么转换的就不多过说。如无符号数40,二进制表示为:

         

有符号数

有符号数稍微要难一点,在有符号数里面第32位用于表示负数或者正数(0表示正数,1表示负数),第32位一般称为”符号位”。有符号数中正数的表示方法和无符号数都表示一样。如有符号数+40,二进制表示为:

         

如何表示一个有符号数的负数,这个负数的绝对值取反加1,这个过程加做补码,补码就是为了解决负数在二进制中的表示。如有符号数-40,二进制计算过程为:

         +
 ———————————————-
         -

按位非(NOT)

按位非由一个波浪线(~)表示,按位非的操作是将给定的数值按位取反,如:

 var test = 40;

  二进制为:
 0000 0000 0000 0000 0000 0000 0010 1000

 test = ~test;

 二进制为:
 1111 1111 1111 1111 1111 1111 1101 0111

按位与(AND)

按位与由一个和符号表示(&),按位与有两个操作数,分别对两个操作数进行按位对比,如果对应的位上都为1则当前位返回1,如果对应的位上有一个为0则返回当前位0,如:

 var test1 = 40;

  二进制为:
 0000 0000 0000 0000 0000 0000 0010 1000 

 var test2 = 50;

 二进制为:
 0000 0000 0000 0000 0000 0000 0011 0010 

 var test3 = test1 & test2; 

 二进制为:
 0000 0000 0000 0000 0000 0000 0010 0000

按位或(OR)

按位或由一个竖线符号(|)表示,按位或有两个操作数,分别对两个操作数进行按位对比,对应的位上只要有一个为1则返回当前位1,如果都为0则返回当前位为0。如:

 var test1 = 40; 

 二进制为:
 0000 0000 0000 0000 0000 0000 0010 1000 

 var test2 = 50; 

 二进制为:
 0000 0000 0000 0000 0000 0000 0011 0010 

 var test3 = test1 | test2;

 二进制为:
 0000 0000 0000 0000 0000 0000 0011 1010 

按位异或(XOR)

按位异或由一个插入符号(^)表示,按位异或有两个操作数,分别对两个操作数进行按位对比,对应的位上只要有一个1则返回当前位1,如果都是1或者都是0则返回当前位0

 var test1 = 40; 

 二进制为:
 0000 0000 0000 0000 0000 0000 0010 1000

 var test2 = 50; 

 二进制为:
 0000 0000 0000 0000 0000 0000 0011 0010 

 var test3 = test1 | test2; 

 二进制为:
 0000 0000 0000 0000 0000 0000 0001 1010

左移(<<)

左移操作符由两个小于号表示(<<),左移操作符用于将当前数值从第0位开始按位向左移。如:

 var test = 2; 

 二进制为:10 

 var newTest = 2 << 5;

 二进制为:
 1000000

有符号数右移(>>)

有符号数右移由两个大于符号(>>)组成,有符号数由于第32位是符号位,所以不会移动符号位,所以从第31位右移,但是右移过程中产生的空位用符号位的值来填充。如下例用8位来示范:

 var test = -2; 

 二进制为:
 1000 0010 

 var newTest = 2 >> 5;
 二进制为:
 11111100

无符号数右移(>>>)

无符号数右移由三个大于符号组成(>>>),无符号数第32位不属于符号位,所以右移的时候是从第32位开始移动。如下例用8位来示范:

 var test = 2; 

 二进制为:
 0000 0010 

 var newTest = 2 >>> 5; 

 二进制为:
 0000 0000

ECMAScript位操作符的更多相关文章

  1. 浅谈JavaScript位操作符

    因为ECMAscript中所有数值都是以IEEE-75464格式存储,所以才会诞生了位操作符的概念. 位操作符作用于最基本的层次上,因为数值按位存储,所以位操作符的作用也就是操作数值的位.不过位操作符 ...

  2. 为什么不要在 JavaScript 中使用位操作符?

    如果你的第一门编程语言不是 JavaScript,而是 C++ 或 Java,那么一开始你大概会看不惯 JavaScript 的数字类型.在 JavaScript 中的数字类型是不区分什么 Int,F ...

  3. C++位操作符总结

    #include <stdio.h> #include <memory.h> #include <malloc.h> #define MaxBinLength 16 ...

  4. C#位操作符

    位操作符是对数据按二进制位进行运算的操作符.c#位操作符包括: 按位与 & 按位或 | 按位取反 ~ 左移 << 右移 >> 例如:   6:00000110 3:00 ...

  5. Java的按位操作符

    本文参考:Java的位操作符 Java的位操作符用来操作整数基本数据类型中的单个"比特"(bit),即代进制位.而我们知道比特就是0和1,那么,位操作就是对这些数据进行基本的操作. ...

  6. 【关于Java移位操作符&按位操作符】

    一.java按位运算符(操作符) 这段时间偶尔看一下源码,会发现有很多很基础的java知识在脑海中已经慢慢的淡成不常用记忆,于是打算捡起来一些. 按位运算符是来操作整数基本数据类型中的单个“比特”(b ...

  7. 原码、反码、补码及位操作符,C语言位操作

    计算机中的所有数据均是以二进制形式存储和处理的.所谓位操作就是直接把计算机中的二进制数进行操作,无须进行数据形式的转换,故处理速度较快. 1.原码.反码和补码 位(bit) 是计算机中处理数据的最小单 ...

  8. C++学习之【使用位操作符求素数分析】

    先放普通代码: #include <iostream> using namespace std; void getPrime_1() { const int MAXN = 100; boo ...

  9. 按位操作符(Bitwise operators)

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

随机推荐

  1. 【转】html input radio取得被选中项的value

    html代码: <input id="rad" name="rad" type="radio" value="1" ...

  2. jsp页面转发到servlet

    一个简单的例子来了解一下jsp页面转发到servlet的过程,环境 eclipse.tomcat 1.工程目录结构如下 2.各部分代码如下 1>index.jsp <%@ page lan ...

  3. lua 学习笔记(一)

    lua 中的方法: 1. type("test"): 返回数据类型 2.#"zhangsan": 返回字符串的长度 3.string.gsub("字符 ...

  4. ThinkPHP函数详解:D方法

    从本篇开始,我们会陆续给大家详细说明下框架内置函数的用法. D方法 D方法应该是用的比较多的方法了,用于实例化自定义模型类,是ThinkPHP框架对Model类实例化的一种封装,并实现了单例模式,支持 ...

  5. jquery选择器及效率问题

    $('p2') //选择名字 $('.class') //选择class $('#id') //选择id $('#id li') //所有id=”id”标签内的li标签 $(“#id”).find(“ ...

  6. android优化(json工具,message新建/传递,avtivity深入学习视频)

    1,在线json校验工具:www.bejson.com 2, 在handler中经常使用的 message的传递上,message.what使用静态量 . private static final i ...

  7. oepn sync

    http://blog.csdn.net/cywosp/article/details/8767327 SYNOPSIS #include <sys/types.h> #include & ...

  8. redis单机及其集群的搭建

    http://www.cnblogs.com/mouseIT/p/5288204.html

  9. 神奇的 BlocksKit(1):源码分析(上)

    高能预警:本篇文章非常长,因为 BlocksKit 的实现还是比较复杂和有意的.这篇文章不是为了剖析 iOS 开发中的 block 的实现以及它是如何组成甚至使用的,如果你想通过这篇文章来了解 blo ...

  10. 解决Android拍照保存在系统相册不显示的问题

    可能大家都知道我们保存相册到Android手机的时候,然后去打开系统图库找不到我们想要的那张图片,那是因为我们插入的图片还没有更新的缘故,先讲解下插入系统图库的方法吧,很简单,一句代码就能实现 Med ...