1.6. Obtaining the Most- or Least-Significant Bits of a Number
Problem
You have a 32-bit integer value that contains information in both its lower and upper 16 bits. You need a method to get the 16 most-significant bits and/or the 16 least-significant bits of this value.
Solution
To get the most-significant bits (MSB) of an integer value, perform a
bitwise and between it and the value shown in the
following method:
public static int GetMSB(int intValue)
{
return (intValue & 0xFFFF0000);
}To get the least-significant bits (LSB) of a value, use the following method:
public static int GetLSB(int intValue)
{
return (intValue & 0x0000FFFF);
}This technique can easily be modified to work with other sizes of integers (e.g., 8-bit, 16-bit, or 64-bit); this trick is shown in the Discussion section.
Discussion
In order to determine the values of the MSB of a number, use the
following bitwise AND operation:
uint intValue = Int32.MaxValue; uint MSB = intValue & 0xFFFF0000; // MSB == 0xFFFF0000
This method simply ANDs the number to another
number with all of the MSB set to 1. This method
will zero out all of the LSB, leaving the MSB intact.
In order to determine the values of the LSB of a number, use the
following bitwise AND operation:
uint intValue = Int32.MaxValue; uint LSB = intValue & 0x0000FFFF; // LSB == 0x0000FFFF
This method simply ANDs the number to another
number with all of the LSB set to 1, which zeroes
out all of the MSB, leaving the LSB intact.
The methods presented here accept only ...