操作符-位操作符

1.按位非(NOT)

按位非操作符由一个波浪线(~)表示,执行安慰非的结果就是返回数值的反码。按位非操作的本质:操作数的负值-1。

var num=25;
var num2=~num1;
alert(num2);//-26

2.按位与(AND)
按位与操作符由一个和号字符(&)表示,它有两个操作符数。

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

简而言之,按位与操作只在两个数值的对应位置都是1时才返回1,任何一位是0,结果都是0;例如:

var result=25&3;
alert(result);//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

3.按位或(OR)

按位或操作符由一个竖线符号(|)表示,同样也有两个操作数。

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

按位或操作在有一个位是1的情况下就返回1,而只有在两个位都是0的情况下才返回0;

如下例子对25和3执行按位或操作:

var result=25|3;
alert(result);//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

3.按位异或(XOR)

按位异或操作符由一个插入符号(^)表示,也有两个操作数。

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

按位异或与按位或的不同之处在于,这个操作在两个数值对应位上只有一个1时才返回1,如果对应的两位都是1或都是0,则返回0。

对25和3执行按位异或操作的代码如下:

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

25与3按位异或的结果是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

5.左移

左移操作符由两个小于号(<<)表示,这个操作符会将数值的所有位向左移动指定的位数。

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

在向左移位后,原数值的左侧多出5位空位。左移操作会以0来填充这些空位,以便得到的结果是一个完整的32位二进制数。

6.有符号的右移

有符号的右移操作由两个大于号(>>)表示,这个操作符将数值向右移动,但保留符号位(即正负号标记)。有符号的右移操作与左移操作恰好相反。

7.无符号右移

无符号右移操作符由3个大于号(>>>)表示,这个操作符将数值的所有32位都向右移动,对正位数来说,无符号右移的结果与有符号的右移相同。

时间: 2024-10-31 07:07:23

操作符-位操作符的相关文章

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

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

【JavaScript】JavaScript位操作符

JavaScript位操作符 位操作符用于在最基本的层次上,即按内存中表示数值的位来操作数值.ECMAScript 中的所有数值都以 IEEE-754 64 位格式存储,但位操作符并不直接操作 64 位的值.而是先将 64 位的值转换成 32 位的整数,然后执行操作,最后再将结果转换回 64 位.对于开发人员来说,由于 64 位存储格式是透明的,因此整个过程就像是只存在 32 位的整数一样. 对于有符号的整数,32 位中的前 31 位用于表示整数的值.第 32 位用于表示数值的符号:0 表示正数

为什么不要在 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=

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

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

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

众所周知,位操作是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