Java 中的位运算:
>>> 无符号右移和 >> 右移的区别
- 无符号右移动右边用0补齐。>>右移动,如果说符号位是1,则右边用1填充,如果是0则用0填充。0代表的是 正数,1代表的是负数。
- 二进制负数 的计算方法 ,二进制的补位加1就是她的值;
在计算机中负数采用二进制的补码表示,10进制转为二进制得到的是源码,将源码按位取反得到的是反码,反码加1得到补码;例如(1的二进制为 0000 0001 ;他的反码是1111 1110 ;加1得到 1111 1111 这就是-1)
二进制的最高位是符号位,0表示正,1表示负。
1: ^(亦或运算),针对二进制,相同的为0,不同的为1;
代码如下:
public static void main(String[] args) {
System.out.println("2的二进制表达:"+Integer.toBinaryString(2));
System.out.println("3的二进制表达:"+Integer.toBinaryString(3));
System.out.println("2^3运算的结果是 :"+(2^3));
//控制台的输出:
/* 2的二进制表达:10
3的二进制表达:11
2^3运算的结果是 :1*/
}
2:&(与运算) 针对二进制,只要有一个为0,就为0
代码如下:
System.out.println("2的二进制表达:"+Integer.toBinaryString(2));
System.out.println("3的二进制表达:"+Integer.toBinaryString(3));
System.out.println("2&3运算的结果是 :"+(2&3));
//控制台的输出:
/* 2的二进制表达:10
3的二进制表达:11
2&3运算的结果是 :2*/
3:<<(向左位移) 针对二进制,转换成二进制后向左移动N位,后面用0补齐
代码如下:
System.out.println("2的二进制表达:"+Integer.toBinaryString(2));
System.out.println("3的二进制表达:"+Integer.toBinaryString(3));
System.out.println("2<<3运算的结果是 :"+(2<<4));
System.out.println("-96的二进制表达:"+Integer.toBinaryString(-96));
System.out.println("-96<<1运算的结果是 :"+(-96<<1));
//控制台的输出:
/* 2的二进制表达:10
3的二进制表达:11
2<<3运算的结果是 :32
-96的二进制表达:11111111111111111111111110100000
-96<<1运算的结果是 :-192
*/
4:>>(向右位移) 针对二进制,转换成二进制后向右移动n位(最高位需要保持不变,考虑最高位符号0代表正数,1代表负数)
代码如下:
public static void main(String[] args) {
System.out.println("2的二进制表达:"+Integer.toBinaryString(2));
System.out.println("3的二进制表达:"+Integer.toBinaryString(3));
System.out.println("2>>3运算的结果是 :"+(2>>1));
//控制台的输出:
/* 2的二进制表达:10
3的二进制表达:11
2>>3运算的结果是 :1*/
}
5:>>>(无符号右移) 无符号右移,忽略符号位,空位都以0补齐
10进制转二进制的时候,因为二进制数一般分8位、 16位、32位以及64位 表示一个十进制数,所以在转换过程中,最高位会补零。
在计算机中负数采用二进制的补码表示,10进制转为二进制得到的是源码,将源码按位取反得到的是反码,反码加1得到补码
二进制的最高位是符号位,0表示正,1表示负
>>>与>>唯一的不同是它无论原来的最左边是什么数,统统都用0填充。
——比如,byte是8位的,-1表示为byte型是11111111(补码表示法)
b>>>4就是无符号右移4位,即00001111,这样结果就是15。
可见正数做>>>运算的时候和>>是一样的。区别在于负数运算
无符号右移规则和右移运算是一样的,只是填充时不管左边的数字是正是负都用0来填充,无符号右移运算只针对负数计算,因为对于正数来说这种运算没有意义
无符号右移运算符>>> 只是对32位和64位的值有意义
代码如下:
public static void main(String[] args) {
System.out.println("16的二进制表达:"+Integer.toBinaryString(16));
System.out.println("-16的二进制表达:"+Integer.toBinaryString(-16));
System.out.println("16>>2运算的结果是 :"+((16)>>2));
System.out.println("-16>>2运算的结果是 :"+((-16)>>2));
System.out.println("16>>>2运算的结果是 :"+((16)>>>2));
System.out.println("-16>>>2运算的结果是 :"+((-16)>>>2));
//控制台的输出:
// 16的二进制表达:10000
// -16的二进制表达:11111111111111111111111111110000
// 16>>2运算的结果是 :4
// -16>>2运算的结果是 :-4
// 16>>>2运算的结果是 :4
// -16>>>2运算的结果是 :1073741820
}
```