Zero. Learning objectives of this lecture
- Understand the meaning of bit operation
- Master the use of bit operation
1, Bit operator concept
- Bit operators are symbols that operate on each bit of binary numbers. They operate specifically on numbers 0 and 1.
2, Bitwise operator usage
(1) Classification description table
operator | operation | example | result |
---|
& | Bitwise AND | a & b | The result of "and" operation for each bit of a and b |
| | Bitwise OR | a | b | The result of "or" operation for each bit of a and b |
~ | Reverse | ~ a | The result of "not" operation for each bit of a |
^ | Bitwise XOR | a ^ b | The result of "XOR" operation for each bit of a and b |
<< | Shift left | a << b | Move a to the left by b, and fill the space on the right with 0 |
>> | Shift right | a >> b | Move a right to bit b, discard the moved out bit, and fill the highest bit on the left with 0 or 1 |
>>> | unsigned right shift | a >>> b | Move a right to bit b, discard the moved out bit, and fill the highest bit on the left with 0 |
- Bitwise and operation truth table
- Truth table of inverse operation
(2) Precautions
The essence of bit operators is to operate on binary numbers 0 and 1. When using bit operators, the operands will be converted into binary numbers for bit operation, and then the results will be converted into the desired binary numbers. Where 1 means true and 0 means false.
(3) Case demonstration
1. Bitwise AND
data:image/s3,"s3://crabby-images/fa634/fa63477f3a82fec500cbdaeec865d877ccdd2cb5" alt=""
2. Bitwise OR
data:image/s3,"s3://crabby-images/41153/411532d7c8e7223b7c858b436a1a11031479f075" alt=""
3. Bit by bit inversion
data:image/s3,"s3://crabby-images/97920/979201f71b1d6009a13efd0a1dbe0776f385744b" alt=""
4. Bitwise XOR
data:image/s3,"s3://crabby-images/02fe5/02fe5516223f661cadadecc9c0f4c706819e9bee" alt=""
5. Shift left
data:image/s3,"s3://crabby-images/28b26/28b2631593ce9d46b67368f2e4b08755c4a2782a" alt=""
6. Shift right
data:image/s3,"s3://crabby-images/5b60e/5b60e5de93296ef57d7a03867058a411d731bd38" alt=""
7. Unsigned right shift
data:image/s3,"s3://crabby-images/f89fe/f89fe99a11761e431a54633bee0c865509227e4f" alt=""
8. Demonstrate various bit operations
data:image/s3,"s3://crabby-images/600e3/600e317f7cd1c5b5e567c238ee7da78b4b6e26b5" alt=""
package net.hw.lesson05;
/**
* Function: demonstrate bit operation
* Author: Wei Hua
* Date: March 22, 2020
*/
public class Example509 {
public static void main(String[] args) {
int a = 0b00000110;
int b = 0b00001011;
// Bitwise AND
System.out.println(Integer.toBinaryString(a) + " & " + Integer.toBinaryString(b) + " = " + Integer.toBinaryString(a & b));
// Bitwise OR
System.out.println(Integer.toBinaryString(a) + " ! " + Integer.toBinaryString(b) + " = " + Integer.toBinaryString(a | b));
// Bit by bit inversion
System.out.println("~" + Integer.toBinaryString(a) + " = " + Integer.toBinaryString(~a));
// Bitwise XOR
System.out.println(Integer.toBinaryString(a) + " ^ " + Integer.toBinaryString(b) + " = " + Integer.toBinaryString(a ^ b));
// Shift left
System.out.println(Integer.toBinaryString(b) + " << 1 = " + Integer.toBinaryString(b << 1));
// Shift right
System.out.println(Integer.toBinaryString(b) + " >> 1 = " + Integer.toBinaryString(b >> 1));
// unsigned right shift
System.out.println(Integer.toBinaryString(b) + " >>> 1 = " + Integer.toBinaryString(b >>> 1));
}
}
- Run the program and view the results
data:image/s3,"s3://crabby-images/9dbf2/9dbf24ce36b30480c383a0b9f2dbdeb86d1a8a39" alt=""
9. Demonstrate the difference between shift right and unsigned right
How can we reflect the difference between right shift and unsigned right shift?
data:image/s3,"s3://crabby-images/9bba7/9bba752cb789833ae27b14916d78c289468fddb7" alt=""
package net.hw.lesson05;
/**
* Function: demonstrate the difference between right shift and unsigned right shift
* Author: Wei Hua
* Date: March 22, 2020
*/
public class Example510 {
public static void main(String[] args) {
int a = 0b00000111111111111111111111111001; // Positive number
int b = 0b10000111111111111111111111111001; // negative
// Shift right
System.out.println(Integer.toBinaryString(a) + " >> 1 = " + Integer.toBinaryString(a >> 1));
// unsigned right shift
System.out.println(Integer.toBinaryString(a) + " >>> 1 = " + Integer.toBinaryString(a >>> 1));
// Shift right
System.out.println(Integer.toBinaryString(b) + " >> 1 = " + Integer.toBinaryString(b >> 1));
// unsigned right shift
System.out.println(Integer.toBinaryString(b) + " >>> 1 = " + Integer.toBinaryString(b >>> 1));
}
}
Run the program and the results are as follows:
data:image/s3,"s3://crabby-images/a7732/a7732b139ccf42edb1c065e7c88d12d4247d1063" alt=""
The highest bit is the sign bit, 0 is a positive number and 1 is a negative number.
For positive numbers, a right shift results in the same way as an unsigned right shift.
For negative numbers, the result of shift right is different from that of unsigned right.
(4) Classroom practice
- Program and calculate the following bit operation results
1,23 & 34
2,23 | 34
3,23 ^ 34
4,~23
5,32 >> 2
6,-32 >> 2
7,32 >>> 2
8,-32 >>> 2
9,4 << 3
data:image/s3,"s3://crabby-images/8df15/8df15f4e2458caaf3872da6e8fdd2b27797b5ebb" alt=""
You can compare the bit operation of Python:
data:image/s3,"s3://crabby-images/df0d5/df0d51dc08db595df16efb181e2612606aa92d97" alt=""
As you can see, except that there is no unsigned right shift operator in Python, other bit operators are exactly the same as Java.