Java零基础学习 移位运算符
Posted 彭老希
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java零基础学习 移位运算符相关的知识,希望对你有一定的参考价值。
一、概念
- << 表示左移,
不分正负数
,低位补0 - >> 表示右移,如果该数为正,则高位补0,若为负数,则高位补1
- >>> 表示无符号右移,也叫逻辑右移,即若该数为正,则高位补0,而若该数为负数,则右移后高位同样补0
概念分解
- << : 左移运算符,num << 1,相当于num乘以2
- >> : 右移运算符,num >> 1,相当于num除以2
- 无符号右移,忽略符号位,空位都以0补齐
二、例子分析
/**
*
*/
public class Test {
public static void main(String[] args) {
int number = 10;
//原始数二进制
printInfo(number);
number = number << 1;
//左移一位
printInfo(number);
number = number >> 1;
//右移一位
printInfo(number);
}
/**
* 输出一个int的二进制数
* @param num
*/
private static void printInfo(int num){
System.out.println(Integer.toBinaryString(num));
}
}
输入结果为:
1010
10100
1010
换算结果:
43210 位数
--------
1010 十进制:10 原始数 number
10100 十进制:20 左移一位 number = number << 1;
1010 十进制:10 右移一位 number = number >> 1;
三、难点理解
对于:>>>
无符号右移,忽略符号位,空位都以0补齐
value >>> num – num 指定要移位值value 移动的位数。
无符号右移的规则
四、其他(拓展)
Java(JDK-8) 编程语言还提供了对整数类型执行按位和位移操作的运算符。
(1)一元按位补码
一元按位补码运算符“ ~”反转位模式;
它可以应用于任何整数类型,使每个“0”成为“1”,每个“1”成为“0”。例如,abyte包含 8 位;
将此运算符应用于位模式为“00000000”的值会将其模式更改为“11111111”。
(2)位移运算
有符号左移运算符“ <<”将位模式左移,有符号右移运算符“ >>”将位模式右移。
位模式由左边的操作数给出,右边的操作数给出要移位的位置数。无符号右移运算符 " >>>" 将零移到最左边的位置,而最左边的位置 after">>"取决于符号扩展。
按位运算&符执行按位 AND 运算。
按位运算^符执行按位异或运算。
按位运算|符执行按位包含或运算。
以下程序 BitDemo使用按位 AND 运算符将数字“2”打印到标准输出。
class BitDemo {
public static void main(String[] args) {
int bitmask = 0x000F;
int val = 0x2222;
// prints "2"
System.out.println(val & bitmask);
}
}
以上是关于Java零基础学习 移位运算符的主要内容,如果未能解决你的问题,请参考以下文章