Práctica de cambio de operación de bits

Los operadores de desplazamiento >>, >>>, <<<<
entre los cuales: >> es el desplazamiento aritmético a la derecha y la vacante a la izquierda se llena con el bit más alto.
Y >>> es un desplazamiento lógico a la derecha (desplazamiento a la derecha sin firmar), que llena la vacante a la izquierda con 0.

public class BitCalcuDemo01
{
    
    
	public static void main(String[] args)
	{
    
    
		int rst1 = (byte)0x80 >> 2; // -32
		int rst2 =       0xa2 >> 2; // 40
		int rst3 = (byte)0xa2 >> 2; // -24
		int rst4 = (byte)0xa2 >>>2; // 1073741800

		// ==========

		System.out.println(rst1);
		System.out.println(0x80); // int:128
		byte tmp1 = (byte)0x80; // -128
		System.out.println(String.format("0x%x",tmp1)); // byte:-128  内存 0x80(-128的补码)
		int tmp12 = tmp1;
		System.out.println(String.format("0x%x",tmp12)); // byte->int 后int中 0xffffff80
		int tmp11 = tmp1 >> 2; // 算术右移2位,最高位1补空位
		System.out.println(String.format("0x%x",tmp11)); // 0xffffffe0(-32的补码)
		System.out.println(tmp11);	// -32
		
		// 强制类型转换:0x00000080 -> 0x80
		// 自动类型转换:0x80 -> 0xffffff80
		// 算术右移:0xffffff80 -> 0xffffffe0

		System.out.println("=============");

		System.out.println(rst2);
		System.out.println(0xa2); // 0x00000a2(十进制是162) 右移后 0x00000028(十进制是40)

		System.out.println("=============");

		System.out.println(rst3);

		// 强制类型转换:0x000000a2(int) -> 0xa2(byte,补码是-94)
		// 自动类型转换:0xa2 -> 0xffffffa2(int,补码是-94)
		// 算术右移:0xffffffa2 -> 0xffffffe8(-24的补码)

		System.out.println("=============");

		System.out.println(rst4);

		// 强制类型转换:0x000000a2(int) -> 0xa2(byte,补码是-94)
		// 自动类型转换:0xa2 -> 0xffffffa2(int,补码是-94)
		// 逻辑右移:0xffffffa2 -> 0x3fffffe8(int, 1073741800) <逻辑右移->>空位补0>‬

	}
}

Supongo que te gusta

Origin blog.csdn.net/qq_43341057/article/details/104707262
Recomendado
Clasificación