位运算符详解

Posted alter888

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了位运算符详解相关的知识,希望对你有一定的参考价值。

位运算符比一般的算术运算符速度要快,而且可以实现一些算术运算符不能实现的功能。如果要开发高效率程序,位运算符是必不可少的。位运算符用来对二进制位进行操作,包括:按位与(&)、按位或(|)、按位异或(^)、按位取反(~)、按位左移(<<)、按位右移(>>)。下面就给大家介绍位运算符的详细用法。

位运算

指定 A = 60(0011 1100); B = 13 (0000 1101)

按位与(&)

对两个数进行操作,然后返回一个新的数,这个数的每个位都需要两个输入数的同一位都为1时才为1

(A & B) 结果为 12, 二进制为 0000 1100

 

按位或(|)

比较两个数,然后返回一个新的数,这个数的每一位设置1的条件是两个输入数的同一位都不为0(即任意一个为1,或都为1)

(A | B) 结果为 61, 二进制为 0011 1101

 

按位异或(^)

比较两个数,然后返回一个数,这个数的每个位设为1的条件是两个输入数的同一位不同,如果相同就设为0

(A ^ B) 结果为 49, 二进制为 0011 0001

 

按位取反(~)

对一个操作数的每一位都取反

(~A ) 结果为 -61, 二进制为 1100 0011

 

按位左移(<<)

将操作数的所有位向左移动指定的位数。

例如:11111111 << 1(11111111 左移一位)的结果。蓝色数字表示被移动位,灰色表示被丢弃位,空位用橙色的0填充。

技术分享图片

 

(A << 2)结果为 240, 二进制为 1111 0000

 

按位右移(<<)

将操作数的所有位向又移动指定的位数。

下图展示了11111111 >> 1(11111111 右移一位)的结果。蓝色数字表示被移动位,灰色表示被丢弃位,空位用橙色的0填充。

技术分享图片

 

A >> 2 结果为 15, 二进制为 0000 1111

 

以上是关于位运算符详解的主要内容,如果未能解决你的问题,请参考以下文章

位运算和典型应用详解

C语言位运算符详解

详解位运算符的一些特点

Java的位运算符详解实例

C语言 位运算符详解 (使用二进制实例深入学习理解位运算符使用原理)

Java千问:Java语言位运算符详解