在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. TCP、UDP、IP包头结构分析(转)

    1.TCP数据段格式 TCP是一种可靠的.面向连接的字节流服务.源主机在传送数据前需要先和目标主机建立连接.然后,在此连接上,被编号的数据段按序收发.同时,要求对每个数据段进行确认,保证了可靠性.如果 ...

  2. [二]poi实践一

    1.创建时间格式的cell 2.创建不同格式的cell(字符串.布尔.数值) 3.读取遍历xls文件 4.抽取excel的内容

  3. WIN10环境下搭建与连接VPN服务器

    搭建VPN服务器 0.前言 1.WIN+E打开此电脑 2.勾选始终显示菜单,并应用,确定 3.新建传入连接,可以添加用户,也可以直接选取已有用户 连接VPN服务器 1.打开vpn设置 2.添加vpn连 ...

  4. scrollTop 值为 0

    由scrollTop兼容问题引起: 在 Firefox 和 IE 中,使用 document.documentElement.scrollTop 获取: 在 Chrome 中,使用 document. ...

  5. OR 改写union数据变少

    <pre name="code" class="sql">SQL> SELECT deptno FROM emp WHERE mgr = 76 ...

  6. mysql中对数据库的每个表执行优化的存储过程

    说明:此处为<高性能mysql(第二版)>中的示例代码,除了数据库名 其他未经更改.仅供学习及参考 对数据库的每个表执行优化的存储过程 CREATE PROCEDURE `inventor ...

  7. How does CCFileUTils::fullPathForFilename work

    OverView The purpose of this document is show you how does function CCFileUtils::fullPathForFilename ...

  8. cocos2dx下最大纹理大小取决于平台

    原文:http://www.cocos2d-x.org/wiki/Max_size_of_textures_in_cocos2d-x_depends_on_each_platform 在理论上,coc ...

  9. Android(java)学习笔记141:SQLiteDatabase的query方法参数分析

    public Cursor query (boolean distinct, String table, String[] columns, String selection, String[] se ...

  10. codeblocks 更改颜色主题

    Code::Blocks是一款优秀的C/C++编辑器,但默认的颜色为白底黑字,并且没有自带更多的主题配置.因此,各种颜色主题需要手动配置. 首先关闭codeblocks软件. 下载文件colour_t ...