1.按位非(NOT)

2.按位与(AND)

3.按位或(OR)

4.按位异或(XOR)

5.左移

6.有符号右移

7.无符号右移

------------------------------------------------------------------------------------------------------------------------------------------------------------------

1.按位非(NOT):

符号:~

功能:返回数值的反码。

var num1 = 25;         //二进制00000000000000000000000000011001
var num2 = ~num1; //二进制11111111111111111111111111100110
alert("num2"); //-26

操作数的负值减1。因此下面的代码也能得到相同的结果:

var num1 = 25;
var num2 = -num1 -1;
alert(num2); // "-26"

按位非是在数值底层操作,因此速度更快。

2.按位与(AND)

符号:&

功能:只在两个数值的对应都是1时才返回1,任何一位是0,结果都是0。如下表:

第一个数值 第二个数值 结果
1 1 1
1 0 0
0 1 0
0 0 0
var result = 25 & 3;
alert(result); //

3.按位或(OR)

符号: |

功能:在有一个位是1的时候就返回1,而只有在两个位都是0的情况下才返回0。

第一个数值 第二个数值 结果
1 1 1
1 0 1
0 1 1
0 0 0
var result = 25 | 3;
alert(result); //

4.按位异或(XOR)

符合:^

功能:在两个位对应只有一个1的时候才返回1,如果对应的两个位是1或0时返回0。

第一个数值 第二个数值 结果
1 1 0
1 0 1
0 1 1
0 0 0

 

var result = 25 ^ 3;
alert("result"); //

5.左移

符号:<<

功能:所有位向左移,右边空出来的用0补。

var oldValue = 2;              //二进制的10
var newValue = oldValue << 5; //等于二进制的1000000,十进制到底64

左移不影响操作数的符号位。

6.有符号右移:

符号:>>

功能:将数值向右移动,保留符号位(正负号),左侧的空位用符号位来填充。

var oldValue = 64;                //二进制的1000000
var newValue = oldValue >> 5; //等于二进制的10,即十进制的2

7.无符号右移:

符号:>>>

功能:正数,同有符号右移;负数,用0填充空位,而不是像正数(有符号右移)以符号位填充空位。

var oldValue = -64;
var newValue = oldValue >>> 5;

《JavaScript高级程序设计》笔记(2):位操作符的更多相关文章

  1. JavaScript高级程序设计笔记(一)

    ---恢复内容开始--- 前三章为基础知识,为了方便以后查看,所以比较啰嗦.这里对函数的基本操作没有记录. 1.JavaScript的实现 虽然 JavaScript 和 ECMAScript 通常都 ...

  2. javascript高级程序设计--笔记01

    概述 JavaScript的实现包含三个部分: 1  核心(ECMAScript)   提供核心语言功能 2  文档对象模型(DOM)  一套提供了访问以及操作网页内容的API 3  浏览器对象模型( ...

  3. javaScript高级程序设计笔记 1

    核心  ECMAScript 文档对象模型  DOM 浏览器对象模型 BOM 延迟脚本  defer typeof操作符      判断字符类型  返回   undefined  boolean  s ...

  4. JavaScript高级程序设计笔记之面向对象

    说起面向对象,大部分程序员首先会想到 类 .通过类可以创建许多具有共同属性以及方法的实例或者说对象.但是JavaScript并没有类的概念,而且在JavaScript中几乎一切皆对象,问题来了,Jav ...

  5. <javascript高级程序设计>笔记

    1.要讲一个值转换成其对应的Boolean类型 ,可以调用转型函数Boolean(). var message=“hello world!”; var messageAsBoolean=Boolean ...

  6. javascript事件小结(事件处理程序方式)--javascript高级程序设计笔记

    1.事件流:描述的是从页面中接收事件的顺序. 2.事件冒泡:IE的事件流叫做事件冒泡,即事件开始从具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播到不具体的节点(文档). 3.事件捕获 ...

  7. Javascript高级程序设计笔记 <第五章> 引用类型

    一.object类型 创建object实例的方式有两种: //第一种使用new操作符跟构造函数 var person= new Object(); person.name="小王" ...

  8. JavaScript高级程序设计笔记 事件冒泡和事件捕获

    1.事件冒泡 要理解事件冒泡,就得先知道事件流.事件流描述的是从页面接收事件的顺序,比如如下的代码: <body> <div> click me! </div> & ...

  9. javaScript高级程序设计笔记 2

    Undefinde Null Boolean Number String    基本类型 Object    引用类型 只有引用类型才能动态的添加属性 赋值基本类型和引用类型也不相同,复制的基本类型的 ...

  10. Javascript高级程序设计笔记(很重要尤其是对象的设计模式与继承)

    var obj = {'a':'a'}; var fun = function (){} console.log(typeof obj);//object console.log(typeof fun ...

随机推荐

  1. iPad开发(相对于iPhone开发时专有的API)

    iPad开发 一.iPad开发简介 1.什么是iPad 一款苹果公司于2010年发布的平板电脑 定价介于苹果的智能手机iPhone和笔记本电脑产品之间 跟iPhone一样,搭载的是iOS操作系统 2. ...

  2. iOS 极光推送

    1.关于推送的几个证书.http://www.mobile-open.com/2016/931624.html 进入开发者中心:https://developer.apple.com/account/ ...

  3. Mac RTX

    http://bbs.weiphone.com/read-htm-tid-1876850.html 公司的rtx还是2010的,如果是2011的就有mac版的了.直接到官网下. 那还是用2010的,尼 ...

  4. 我的Android开发相关文章

    Pro Android学习笔记: Pro Android学习笔记(一零七):2D动画(2):layout渐变动画 2014.7.25 Pro Android学习笔记(一零六):2D动画(1):fram ...

  5. Nginx代码调试——gdb工具

    参考网上的资料,写了一个configprint模块,其功能为打印输出location配置内容,并计数访问次数. 代码链接如下:https://github.com/PaulWeiHan/nginx_m ...

  6. ios的@property属性和@synthesize属性

    当你定义了一系列的变量时,需要写很多的getter和setter方法,而且它们的形式都是差不多的,,所以Xcode提供了@property 和@synthesize属性,@property用在 .h ...

  7. java13 InputStream,Reader

    流的方向: .输入流:数据源到程序(InputStream,Reader读进来). .输出流:程序到目的地(OutPutStream,Writer写出来). 处理数据单元: 字节流:按照字节读取数据( ...

  8. careercup-树与图 4.3

    4.3 给定一个有序整数数组,元素各不相同按升序排列,编写一个算法,创建一棵高度最小的二叉查找树. 解答 想要使构建出来的二叉树高度最小,那么对于任意结点, 它的左子树和右子树的结点数量应该相当.比如 ...

  9. HDU1016(bfs)

    import java.util.Scanner;public class Main1016 { public static void main(String[] args) { Scanner ci ...

  10. 玩转Android之Drawable的使用

    Drawable天天用,可你是否对Drawable家族有一个完整的认知?今天我们就来系统的学习一下Drawable的使用. 1.概述 用过Drawable的筒子都知道Drawable有很多种,有的时候 ...