This post is all about basic understanding of operators that perform bit-wise and bit shift operations on integral types that Java programming language provides.
Note: "
The bitwise
Bitwise XOR operator is denoted by ^ and also work on individual bits. There is no short-circuit XOR operator in Java and result of bitwise XOR operator is XOR operation of individual bits. see the truth table of XOR operation for predicting result. in short bitwise XOR operators will return 1 if both bits are different and return 0 if both bits are same.
The bitwise
The bitwise operators:
Operator | Name | Example | Result | Description |
---|---|---|---|---|
a & b | and | 3 & 5 | 1 | 1 if both bits are 1. |
a | b | or | 3 | 5 | 7 | 1 if either bit is 1. |
a ^ b | xor | 3 ^ 5 | 6 | 1 if both bits are different. |
~a | not | ~3 | -4 | Inverts the bits. |
n << p | left shift | 3 <<< 2 | 12 | Shifts the bits of n left p positions. Zero bits are shifted into the low-order positions. |
n >> p | right shift | 5 >> 2 | 1 | Shifts the bits of n right p positions. If n is a 2's complement signed number, the sign bit is shifted into the high-order positions. |
n >>> p | right shift | -4 >>> 28 | 15 | Shifts the bits of n right p positions. Zeros are shifted into the high-order positions. |
Note: "
<<<
" is not an operator, because it would be redundant. Lets see each operator one by one:The unary bitwise complement operator:
The unary bitwise complement operator "
For example: A
The bitwise
~
" inverts a bit
pattern; it can be applied to any of the integral types, making every
"0" a "1" and every "1" a "0".For example: A
byte
contains 8 bits; applying this operator to a value whose bit pattern is "00000000" would change its pattern to "11111111"
The bitwise &
operator:
Bitwise AND operator works similar to logical AND operator (&&)
and returns 1 if both operands are 1. Difference with bitwise AND and logical
AND also known as short-circuit AND operator is that, logical AND operator
applies only to boolean type. Also bitwise AND operator is denoted by singe & while
short circuit AND operator is denoted by &&.
For example:If A
represent 0010 and B represent 1010 then result of A&B would be
0010.
The bitwise ^
operator:
Bitwise XOR operator is denoted by ^ and also work on individual bits. There is no short-circuit XOR operator in Java and result of bitwise XOR operator is XOR operation of individual bits. see the truth table of XOR operation for predicting result. in short bitwise XOR operators will return 1 if both bits are different and return 0 if both bits are same.
The bitwise |
operator:
Bitwise OR operator is also similar to bitwise AND operator and applies
to individual bits. It’s different than short-circuit OR operator, which is
denoted by (||) and operates on boolean variable. Bitwise OR operator produce
result of OR operation on two bits. Like other
bitwise operator in Java, bitwise OR is only applicable to integral types.
A logical right shift is the converse to the left shift. Rather than moving bits to the left, they simply move to the right. For example, shifting the number 12:
For example, if we interpret this bit pattern as a negative number:
So we see that we have preserved the sign of our negative numbers by using the arithmetic right shift, rather than the logical right shift. And once again, we see that we are performing division by powers of 2.
Here a simple java program showing Bit-wise and bit shift operations:
Left shift (<<)
Integers are stored, in memory, as a series of bits. For example, the number 6 stored as a 32-bit
Note: Shifting left is equivalent to multiplication by powers of 2. So
int
would be:
00000000 00000000 00000000 00000110
Shifting this bit pattern to the left one position (6 << 1
) would result in the number 12:
00000000 00000000 00000000 00001100
As you can see, the digits have shifted to the left by one position,
and the last digit on the right is filled with a zero.Note: Shifting left is equivalent to multiplication by powers of 2. So
6 << 1
is equivalent to 6 * 2
, and 6 << 3
is equivalent to 6 * 8
. A good optimizing compiler will substitute shifts for multiplications when possible.Non-circular shifting :
Please note that these are not circular shifts. Shifting this value to the left by one position (
3,758,096,384 << 1
):11100000 00000000 00000000 00000000
results in 3,221,225,472:11000000 00000000 00000000 00000000
The digit that gets shifted "off the end" is lost. It does not wrap aroundLogical right shift (>>>)
A logical right shift is the converse to the left shift. Rather than moving bits to the left, they simply move to the right. For example, shifting the number 12:
00000000 00000000 00000000 00001100
to the right by one position (12 >>> 1
) will get back our original 6:
00000000 00000000 00000000 00000110
So we see that shifting to the right is equivalent to division by powers of 2.Lost bits are gone
However, a shift cannot reclaim "lost" bits. For example, if we shift this pattern:
00111000 00000000 00000000 00000110
to the left 4 positions (939,524,102 << 4
), we get 2,147,483,744:10000000 00000000 00000000 01100000
and then shifting back ((939,524,102 << 4) >>> 4
) we get 134,217,734:
00001000 00000000 00000000 00000110
We cannot get back our original value once we have lost bits.Arithmetic right shift (>>)
The arithmetic right shift is exactly like the logical right shift, except instead of padding with zero, it pads with the most significant bit. This is because the most significant bit is the sign bit, or the bit that distinguishes positive and negative numbers. By padding with the most significant bit, the arithmetic right shift is sign-preserving.
For example, if we interpret this bit pattern as a negative number:
10000000 00000000 00000000 01100000
we have the number -2,147,483,552. Shifting this to the right 4
positions with the arithmetic shift (-2,147,483,552 >> 4) would
give us:11111000 00000000 00000000 00000110
or the number -134,217,722.So we see that we have preserved the sign of our negative numbers by using the arithmetic right shift, rather than the logical right shift. And once again, we see that we are performing division by powers of 2.
Here a simple java program showing Bit-wise and bit shift operations:
No comments :
Post a Comment