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. Spring Cloud介绍 Spring Cloud与Dubbo对比

    spring Cloud是一个基于Spring Boot实现的云应用开发工具,它为基于JVM的云应用开发中的配置管理.服务发现.断路器.智能路由.微代理.控制总线.全局锁.决策竞选.分布式会话和集群状 ...

  2. Ollivanders: Makers of Fine Wands since 382 BC.

    Ollivanders: Makers of Fine Wands since 382 BC.                                               Time L ...

  3. Maven Build Profiles--reference

    What is Build Profile? A Build profile is a set of configuration values which can be used to set or ...

  4. list add元素覆盖之前元素问题思考

    最近码墙时发现了一个很有意思的问题,定义一个引用对象,如果在循环外面定义对象,在循环里list.add(对象),最后的结果却是所有的对象值都是一样的,即每add一次,都会把之前所有的数据覆盖掉,蛮有趣 ...

  5. js操纵cookie技术

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"% ...

  6. 关于Fragment与Fragment、Activity通信的四种方式

    一直想总结一下Fragment与Fragment.Activity通信的问题,今天有时间一共总结了三种,权当抛砖引玉,如果大家还有更好的方式来实现Fragment和Fragment.Activity的 ...

  7. Android(java)学习笔记148:Eclipse中代码提示去掉@override,不然就报错!

    把项目下载下来后有@Override的注释的方法会报错,如果把@Override去掉就不报错了.经过查阅后发现:@override注释在jdk1.5环境下只能用于对继承的父类的方法的重写,但不能用于对 ...

  8. c语言,strcmp(),字符串比较,看Asic 码,str1>str2,返回值 > 0;两串相等,返回

    #include<stdio.h> #include<string.h> int main() {  char *buffer1="aaa",*buffer ...

  9. Java 字节数组类型(byte[])与int类型互转

    代码如下: public class CommonUtils { //高位在前,低位在后 public static byte[] int2bytes(int num){ byte[] result ...

  10. MySQL5.7.12新密码登录方式及密码策略

    在Centos6.6上安装MySQL5.7.12时,遇到了一个问题 安装后在/root目录下没有发现有.mysql_secret这个文件,所以没有没法按照官方文档上说的那样使用,这里记录下, 解决方式 ...