Java的位运算符详解实例

Posted

tags:

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

Java的位运算符详解实例——与(&)、非(~)、或(|)、异或(^)、右移(>>)、左移(<<)、无符号右移(>>>)

位运算符主要针对二进制,

它包括了:“与”、“非”、“或”、“异或”、"右移"、"左移"、"无符号右移"。

从表面上看似乎有点像逻辑运算符,

但逻辑运算符是针对两个关系运算符来进行逻辑运算,

而位运算符主要针对两个二进制数的位进行逻辑运算。

下面详细介绍每个位运算符。

 

1.与运算符
与运算符用符号“&”表示,其使用规律如下:
两个操作数中位都为1,结果才为1,否则结果为0,例如下面的程序段。
public class demo1
{
public static void main(String[] args)
{
int a=129;
int b=128;
System.out.println("a 和b 与的结果是:"+(a&b));
}
}
运行结果
a 和b 与的结果是:128
下面分析这个程序:
“a”的值是129,转换成二进制就是10000001,而“b”的值是128,转换成二进制就是10000000。根据与运算符的运算规律,只有两个位都是1,结果才是1,可以知道结果就是10000000,即128。

 


2.或运算符
或运算符用符号“|”表示,其运算规律如下:
两个位只要有一个为1,那么结果就是1,否则就为0,下面看一个简单的例子。
public class demo2
{
public static void main(String[] args)
{
int a=129;
int b=128;
System.out.println("a 和b 或的结果是:"+(a|b));
}
}
运行结果
a 和b 或的结果是:129
下面分析这个程序段:
a 的值是129,转换成二进制就是10000001,而b 的值是128,转换成二进制就是10000000,根据或运算符的运算规律,只有两个位有一个是1,结果才是1,可以知道结果就是10000001,即129。

 


3.非运算符
非运算符用符号“~”表示,其运算规律如下:

如果位为0,结果是1,如果位为1,结果是0,下面看一个简单例子。
public class demo3
{
public static void main(String[] args)
{
int a=2;
System.out.println("a 非的结果是:"+(~a));
}
}

运行结果
非a 的结果是:-3

分析上面的程序段:2的二进制是0000 0010 ,进行非运算后1111 1101,所以结果是-3


4.异或运算符
异或运算符是用符号“^”表示的,其运算规律是:
两个操作数的位中,相同则结果为0,不同则结果为1。下面看一个简单的例子。
public class demo4
{
public static void main(String[] args)
{
int a=15;
int b=2;
System.out.println("a 与 b 异或的结果是:"+(a^b));
}
}
运行结果
a 与 b 异或的结果是:13
分析上面的程序段:a 的值是15,转换成二进制为1111,而b 的值是2,转换成二进制为0010,根据异或的运算规律,可以得出其结果为1101 即13

5.>>位移

向右位移运算符号

右边移动的位数舍弃,在左边补位

public class demo5
{
public static void main(String[] args)
{
int a=7;
System.out.println(Integer.toBinaryString(a));
System.out.println("a 右移的结果是:"+(a>>1));
}
}

运行结果
a 右移的结果是:3
分析上面的程序段:a 的值是0111,右移1位,得其结果为0011 即3

6.<<位移

向左位移运算符号

左边移动的位数舍弃,在右边补位

public class demo6
{
public static void main(String[] args)
{
int a=-7;
System.out.println(Integer.toBinaryString(a));
System.out.println("a 右移的结果是:"+(a
<<1));
}
}

运行结果
a 左移的结果是:-14
分析上面的程序段:a 的值是1111 1001,左移1位,得其结果为1111 0010 即-14

7.>>>位移

无符号右移

右边移动的位数舍弃,在左边补0

public class demo7
{
public static void main(String[] args)
{
int a = 7;

int b = -7;


System.out.println(Integer.toBinaryString(a));

System.out.println(Integer.toBinaryString(b));
System.out.println("a
无符号右移的结果是:"+(a>>>1));

System.out.println("b无符号右移的结果是:"+(b>>>1));  
}
}

运行结果
a 无符号右移的结果是:3

无符号右移的结果是:2147483644
分析上面的程序段:

a 的值是0000 0111,右移1位,得其结果为0000 0011 即3

b 的值是1111 1111 1111 1111 1111 1111 1111 1001,右移1位,

得其结果为0111 1111 1111 1111 1111 1111 1111 1100 即2147483644

 

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

Java的位运算符详解实例——与(&)非(~)或(|)异或(^)

Java的位运算符详解实例——与(&)非(~)或(|)异或(^)(仅作记录)

Java的位运算符实例——与(&)非(~)或(|)异或(^)

java中的位运算符及其用法。

java运算符

Java千问:Java位运算经典应用