java 无符号右移_Java 无符号右移与右移运算符的使用介绍

Java 无符号右移介绍

最近学习Java,看到>>>运算符不太了解,也百度查了查,解释得不是很清晰。那么下面讲解我对>>>运算符的认识: >>>运算符:无符号右移运算符 在学习>>>无符号右移运算符前,我们先了解右移运算符>>

下表列出了位运算符的基本运算,假设整数变量A的值为60和变量B的值为13:

操作符

描述

例子

如果相对应位都是1,则结果为1,否则为0

(A&B),得到12,即0000 1100

|

如果相对应位都是0,则结果为0,否则为1

(A | B)得到61,即 0011 1101

^

如果相对应位值相同,则结果为0,否则为1

(A ^ B)得到49,即 0011 0001

按位取反运算符翻转操作数的每一位,即0变成1,1变成0。

(〜A)得到-61,即1100 0011

<<

按位左移运算符。左操作数按位左移右操作数指定的位数。

A << 2得到240,即 1111 0000

>>

按位右移运算符。左操作数按位右移右操作数指定的位数。

A >> 2得到15即 1111

>>>

按位右移补零操作符。左操作数的值按右操作数指定的位数右移,移动得到的空位以零填充。

A>>>2得到15即0000 1111

右移运算符

>>右移运算符:正数高位补0,负数高位补1

看一个例子:

public static void main(String[] args) {

/**

* 10的二进制:1010

* 因为是正数,所以计算机高位的0不会输出

* 负数会输出32位bit

*/

System.out.println(Integer.toBinaryString(10 >> 2));

System.out.println(Integer.toBinaryString(-10));

System.out.println(Integer.toBinaryString(-10 >> 2));

}

输出:

c8cd1398aacf11a6a32973b10391ec5e.png

计算机计算数据以补码的方式进行计算

正数原码、反码、补码不变

负数(-10):以8bit(位)表示

原码----> 1000 1010

反码----> 1111 0101(符号位不变,其他位取反)

补码----> 1111 0110(反码基础上 + 1)

所以会 -10 会输出:1111…0110

-10 >> 2 :1111…1101(高位补1)

10 >> 2:0000…0010

无符号右移运算符

>>> 无符号右移运算符与 >> 右移运算符的正数相同,只不过关键在于负数的不同,>>>运算符右移:**负数高位补 0 ,其它位不变**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值