public class test {
public static void main(String[] args){
//1、左移
System.out.println(5<<2);
//0101左移2位==》010100==》20
//2、右移
System.out.println(5>>2);
//0101右移2位==》0001==》1
//3、无符号右移(>>>)
System.out.print(5>>3);
//0101==>0000==>0
System.out.print(-5>>3);
//11111111 11111111 11111111 11111011==>11111111111 11111111 11111111 11111==>-1
System.out.println(-5>>>3);
//11111111 11111111 11111111 11111011==>0001111111 11111111 11111111 111111==>536870911
/**
* 正数右移,高位用0补,负数右移,高位用1补,当负数使用无符号右移时,用0进行补位(负数变成了正数)
*/
/**
* 附注
* 00000000 00000000 00000000 00000101 是 5的 原码。
反码:将二进制数按位取反,所得的新二进制数称为原二进制数的反码。
取反操作指:原为1,得0;原为0,得1。(1变0; 0变1)
比如:将00000000 00000000 00000000 00000101每一位取反,得11111111 11111111 11111111 11111010。
称:11111111 11111111 11111111 11111010 是 00000000 00000000 00000000 00000101 的反码。
反码是相互的,所以也可称:
11111111 11111111 11111111 11111010 和 00000000 00000000 00000000 00000101 互为反码。
补码:反码加1称为补码。
也就是说,要得到一个数的补码,先得到反码,然后将反码加上1,所得数称为补码。
比如:00000000 00000000 00000000 00000101 的反码是:11111111 11111111 11111111 11111010。
那么,补码为:
11111111 11111111 11111111 11111010 + 1 = 11111111 11111111 11111111 11111011
所以,-5 在计算机中表达为:11111111 11111111 11111111 11111011。转换为十六进制:0xFFFFFFFB。
*/
//4、位与(&)
System.out.print(5&3);//结果为1
//相同为1,不同为0
//5、位或(|)
System.out.print(5|3);//结果为7
//只要有一个为1即为1
//6、位异或(^)
System.out.print(5^3);//结果为6
//相异为1,相同为0
//7、位非(~)
System.out.print(~5);//结果为-6
//0取1,1取0
}
}
Java 位运算
最新推荐文章于 2022-02-18 12:12:16 发布