JS位操作符

位运算 NOT
位运算 NOT 由否定号(~)表示,它是 ECMAScript 中为数不多的与二进制算术有关的运算符之一。

位运算 NOT 是三步的处理过程:

1.把运算数转换成 32 位数字
2.把二进制数转换成它的二进制反码
3.把二进制数转换成浮点数
例如:

var iNum1 = 25;  //25 等于      00000000000000000000000000011001
var iNum2 = ~iNum1; //转换为 11111111111111111111111111100110
alert(iNum2);  //输出 "-26"位运算 NOT 实质上是对数字求负,然后减 1,因此 25 变 -26。用下面的方法也可以得到同样的方法:

var iNum1 = 25;
var iNum2 = -iNum1 -1;
alert(iNum2); //输出 -26位运算

位运算 AND 
位运算 AND 由和号(&)表示,直接对数字的二进制形式进行运算。它把每个数字中的数位对齐,然后用下面的规则对同一位置上的两个数位进行 AND 运算:

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

例如,要对数字 25 和 3 进行 AND 运算,代码如下所示:

var iResult = 25 & 3;
alert(iResult); //输出 "1"25 和 3 进行 AND 运算的结果是 1。为什么?分析如下:

25 = 0000 0000 0000 0000 0000 0000 0001 1001
    3 = 0000 0000 0000 0000 0000 0000 0000 0011
---------------------------------------------
AND = 0000 0000 0000 0000 0000 0000 0000 0001

可以看出,在 25 和 3 中,只有一个数位(位 0)存放的都是 1,因此,其他数位生成的都是 0,所以结果为 1。

位运算 OR
位运算 OR 由符号(|)表示,也是直接对数字的二进制形式进行运算。在计算每位时,OR 运算符采用下列规则:

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

仍然使用 AND 运算符所用的例子,对 25 和 3 进行 OR 运算,代码如下:

var iResult = 25 | 3;
alert(iResult); //输出 "27"25 和 3 进行 OR 运算的结果是 27:

25 = 0000 0000 0000 0000 0000 0000 0001 1001
  3 = 0000 0000 0000 0000 0000 0000 0000 0011
--------------------------------------------
OR = 0000 0000 0000 0000 0000 0000 0001 1011

可以看出,在两个数字中,共有 4 个数位存放的是 1,这些数位被传递给结果。二进制代码 11011 等于 27。

位运算 XOR
位运算 XOR 由符号(^)表示,当然,也是直接对二进制形式进行运算。XOR 不同于 OR,当只有一个数位存放的是 1 时,它才返回 1。真值表如下:

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

对 25 和 3 进行 XOR 运算,代码如下:

var iResult = 25 ^ 3;
alert(iResult); //输出 "26"25 和 3 进行 XOR 运算的结果是 26:

25 = 0000 0000 0000 0000 0000 0000 0001 1001
    3 = 0000 0000 0000 0000 0000 0000 0000 0011
---------------------------------------------
XOR = 0000 0000 0000 0000 0000 0000 0001 1010

可以看出,在两个数字中,共有 4 个数位存放的是 1,这些数位被传递给结果。二进制代码 11010 等于 26。

左移运算
左移运算由两个小于号表示(<<)。它把数字中的所有数位向左移动指定的数量。例如,把数字 2(等于二进制中的 10)左移 5 位,结果为 64(等于二进制中的 1000000):

var iOld = 2;  //等于二进制 10
var iNew = iOld << 5; //等于二进制 1000000 十进制 64注意:在左移数位时,数字右边多出 5 个空位。左移运算用 0 填充这些空位,使结果成为完整的 32 位数字。

注意:左移运算保留数字的符号位。例如,如果把 -2 左移 5 位,得到的是 -64,而不是 64。“符号仍然存储在第 32 位中吗?”是的,不过这在 ECMAScript 后台进行,开发者不能直接访问第 32 个数位。即使输出二进制字符串形式的负数,显示的也是负号形式(例如,-2 将显示 -10。)

有符号右移运算
有符号右移运算符由两个大于号表示(>>;)。它把 32 位数字中的所有数位整体右移,同时保留该数的符号(正号或负号)。有符号右移运算符恰好与左移运算相反。例如,把 64 右移 5 位,将变为 2:

var iOld = 64;  //等于二进制 1000000
var iNew = iOld >> 5; //等于二进制 10 十进制 2同样,移动数位后会造成空位。这次,空位位于数字的左侧,但位于符号位之后。ECMAScript 用符号位的值填充这些空位,创建完整的数字,如下图所示:

无符号右移运算
无符号右移运算符由三个大于号(>>>)表示,它将无符号 32 位数的所有数位整体右移。对于正数,无符号右移运算的结果与有符号右移运算一样。

用有符号右移运算中的例子,把 64 右移 5 位,将变为 2:

var iOld = 64;  //等于二进制 1000000
var iNew = iOld >>>5; //等于二进制 10 十进制 2对于负数,情况就不同了。

无符号右移运算用 0 填充所有空位。对于正数,这与有符号右移运算的操作一样,而负数则被作为正数来处理。

由于无符号右移运算的结果是一个 32 位的正数,所以负数的无符号右移运算得到的总是一个非常大的数字。例如,如果把 -64 右移 5 位,将得到 134217726。如果得到这种结果的呢?

要实现这一点,需要把这个数字转换成无符号的等价形式(尽管该数字本身还是有符号的),可以通过以下代码获得这种形式:

var iUnsigned64 = -64 >>> 0;

然后,用 Number 类型的 toString() 获取它的真正的位表示,采用的基为 2:

alert(iUnsigned64.toString(2));

这将生成 11111111111111111111111111000000,即有符号整数 -64 的二进制补码表示,不过它等于无符号整数 4294967232。

出于这种原因,使用无符号右移运算符要小心。

下常用的javascript位运算符的技巧

js位运算来判断奇偶数

if(n&1===0){
//偶数
}else{
//奇数
}

js位运算符来代替Math.floor

(2.9|0)===2
(~~2.9)===2
(2.9>>>0)===2
(2.9>>0)===2
(2.9<<0)===2
//注意
~~(-2.999);//= -2
Math.floor(-2.999);// = -3RGB2HEX
function RGB2HEX(a,b,c){return"#"+((256+a<<8|b)<<8|c).toString(16).slice(1)}

//或者

function toHexString(r,g,b) {
  return ("00000" + (r << 16 | g << 8 | b).toString(16)).slice(-6);
}
var hex = toHexString(red, green, blue);检测相等关系
if(a!=123)
if(a^123)
//注意:
false ^ 1 // 1
true ^ 1 // 0
2 ^ 1 // 3
{} ^ 1 // 1这个很好用的,比如下面的代码
var isReady = 0;

// somewhere else
if( isReady ) { }

// somewhere else, set isReady state to 1
isReady ^= 1;

// somewhere else, set isReady state to 0
isReady ^= 1;默认值
if (!n) n = defaultValue;
n||(n=defaultValue);
indexOf和~

在代码中常使用String.indexOf,例如:

‘abc‘.indexOf(‘d‘)===-1;
if(‘abc‘.indexOf(str)!==-1){
//在字符串中
}

我们可以这样来写

~‘abc‘.indexOf(‘d‘)===0;
if(~‘abc‘.indexOf(‘d‘)){
//在字符串中
}
if(!~‘abc‘.indexOf(‘d‘)){
//不在字符串中
}

当然javascript的位运算符会导致代码的可读性降低,所以在使用的时候要权衡

时间: 2024-10-28 09:44:53

JS位操作符的相关文章

前端学习笔记之六——JS位操作符练习题

作业题如下: -------------------------------------------------- 位操作符还不是很熟悉,借助这个题正好补一下. 十进制转二进制方法:将十进制数除以2取第一个余数,然后用商不断除以2,不断取第二.第三个……余数,直到商为0时止,然后将第一个.第二个……从右向左排列,高位补0. 二进制转十进制方法:从二进制数最右边的数开始,从左至右,每位数依次乘以2的0次方.2的1次方.2的2次方,然后将这些乘方结果相加,即为十进制数. 所以,本道题十进制22转为二

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

如果你的第一门编程语言不是 JavaScript,而是 C++ 或 Java,那么一开始你大概会看不惯 JavaScript 的数字类型.在 JavaScript 中的数字类型是不区分什么 Int,Float,Double,Decimal 的.咳咳,我说的当然是在 ES6 之前的 JS,在 ES6 的新标准中提出了像 Int8Array 这样新的数据类型.不过这不是本文叙述的重点,暂且就不谈啦.本文将更着重地谈 JS 的数字类型以及作用于它的位操作符,而关于包装对象 Number 的更多了解可以

20160402_C语言位操作符的使用

C语言的设计具备了汇编语言的运算能力,它支持全部的位操作符. 位操作符是对字节或字中的位进行测试.置位或移位处理,在对微处理器的编程中,特别适合对寄存器.I/O端口进行操作. 6种位操作符: (1) & :按位“与”——仅当两个操作数为1时,结果为1,否则为0.如:1000 1000  & 1000 0001  = 1000 0000: (2) | :按位“或”——仅当两个操作数为0时,结果为0,否则为1.如:1000 1000 | 1000 0001 = 1000 1001: (3) ^

神奇的位操作符

相信学过C语言的小伙伴们都知道位操作符,正确的使用位操作符会让我们写出更高效率的程序 但不要忘记它也是有缺点的:只能用于整型和字符型数据. 速度:快于乘法 等同于加减法 *参与运算的数据以补码形式出现!(不要弄错啦!) eg: 数字 -1 原码:10000000 00000000 00000000 00000001 反码:11111111 11111111 11111111 11111110 补码:11111111 11111111 11111111 11111111 ***有符号数只改变数值部

几种常用过的按位操作符技术

控制硬件时常涉及到打开/关闭特定的位或查看它们的状态.按位操作符(<<,>>,~,&,|,^)提供了这种能力.下面的例子中,lottabits表示一个值,bit表示特定位的值.位从右到左进行编号,从0开始,因此,第n位的值为2的n次方(通常情况下只有一位为1,这是为了简洁处理).例如,只有第3位为1的整数的值为2的3次方.(<C++ Primer Plus>附录E) 1.打开位  //打开位,将打开lottabits中对应于bit表示的位  lottabits=

利用位操作符加速程序的运行

众所周知,位操作是cpu里面最快速的操作之一.但是以前在程序中,一直没有使用,可能是害怕异或是别的什么原因.可是最近在写一个小的爬虫,但是却需要爬取百万级数据,这时候想到了位操作符. 先来2个程序对比一下: 程序1: 1 #coding:utf-8 2 3 import time 4 import datetime 5 6 pagesNum = 0 7 8 def getLinks(): 9 global pagesNum 10 for i in range(0,0xfffffff): 11 p

C++位操作符总结

1 #include <stdio.h> 2 #include <memory.h> 3 #include <malloc.h> 4 #define MaxBinLength 16 5 6 //获取无符号数的二进制,这是我自己写的,更简单的方法可以用bitset代替 7 char* getUnsignedBinary(unsigned int num) 8 { 9 int len = MaxBinLength -1; 10 char *bin = (char*)mall

Java的按位操作符

本文参考:Java的位操作符 Java的位操作符用来操作整数基本数据类型中的单个"比特"(bit),即代进制位.而我们知道比特就是0和1,那么,位操作就是对这些数据进行基本的操作.如果基本类型是char.byte或者short类型的数值进行移位处理,那么会转化成int类型,再进行移位的处理 Java的按位操作符 按位操作符会对两个参数对应的位执行布尔代数运算,并最终生成一个结果.这个操作符有与(&).非(~).或(|).异或(^).我们知道单位"比特"(bi

Java知识系统回顾整理01基础04操作符04位操作符

一.位操作符 位操作符在实际工作中用的并不常见,但是我比较纠结这些位操作.所以实际练习位操作符的每一个操作符的操作实例来理解其具体含义. ? ? 建议:?如果确实感兴趣,就看看,个人建议跳过这个章节. 真正工作用到了,再来看. ? ? 二.一个整数的二进制表达 位操作都是对二进制而言的,但是我们平常使用的都是十进制比如5. 而5的二进制是101. 所以在开始学习之前,需要掌握一个整数的二进制表达是多少. 通过Integer.toBinaryString() 方法,将一个十进制整数转换为一个二进制