Java 中的位运算右移算子\n
Java 支持两种类型的右移算子。>> 算子是有符号右移算子,而 >>> 算子是无符号右移算子。左操作数的值向右移动右操作数指定的位数。
有符号右移算子
有符号右移算子 '>>' 使用符号位填充尾随位置。例如,如果数字为正,则将 0 用于填充尾随位置,如果数字为负,则将 1 用于填充尾随位置。
假设 a = 60 和 b = -60;现在,以二进制格式,它们将如下所示 −
a = 0000 0000 0000 0000 0000 0000 0011 1100 b = 1111 1111 1111 1111 1111 1111 1100 0100
在 Java 中,负数以 2 的补码的形式存储。
Thus a >> 1 = 0000 0000 0000 0000 0000 0000 0001 1110 And b >> 1 = 1111 1111 1111 1111 1111 1111 1110 0010
无符号右移算子
无符号右移算子 '>>>' 不使用符号位填充尾随位置。它始终用 0 填充尾随位置。
Thus a >>> 1 = 0000 0000 0000 0000 0000 0000 0001 1110 And b >>> 1 = 0111 1111 1111 1111 1111 1111 1110 0010
示例
public class Tester {
public static void main(String[] args) {
int a = 60; int b = -60; int c = 0;
System.out.println("60 = " + Integer.toBinaryString(a));
System.out.println("-60 = " + Integer.toBinaryString(b));
//signed shift
c = a >> 1;
System.out.println("60 >> 1 = " + Integer.toBinaryString(c));
//unsigned shift
c = a >>> 1;
System.out.println("60 >>> 1 = " + Integer.toBinaryString(c) );
c = b >> 1;
System.out.println("-60 >> 1 = " + Integer.toBinaryString(c) );
c = b >>> 1;
System.out.println("-60 >>> 1 = " + Integer.toBinaryString(c));
}
}输出
60 = 111100 -60 = 11111111111111111111111111000100 60 >> 1 = 11110 60 >>> 1 = 11110 -60 >> 1 = 11111111111111111111111111100010 -60 >>> 1 = 1111111111111111111111111100010
广告
数据结构
网络
关系型数据库管理系统
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
JavaScript
PHP