A DESCRIPTION OF THE PROBLEM :
When the Integer.MAX VALUE bit is set, the get(int, int) function always returns a BitSet of size 0.
This is because length() overflows when Integer.MAX VALUE is set and so returns Integer.MIN VALUE.
public BitSet get(int fromIndex, int toIndex) {
checkRange(fromIndex, toIndex);
checkInvariants();
int len = length(); // (*)
// If no set bits in range return empty bitset
if (len <= fromIndex || fromIndex == toIndex)
return new BitSet(0);
...
When the comparison len <= fromIndex is done, this always evaluates to true regardless of the value of fromIndex, and as such the function returns BitSet(0).
STEPS TO FOLLOW TO REPRODUCE THE PROBLEM :
Create a BitSet with the default constructor, and set the Integer.MAX VALUE bit. Next, set bit 999.
Then do BitSet.get(0, 1000).
EXPECTED VERSUS ACTUAL BEHAVIOR :
EXPECTED -
A BitSet is returned with length = 1000 and size = 1024. In the resulting BitSet, the bit with index 999 is set.
ACTUAL -
A BitSet is returned with length and size = 0. The bit with index 999 is not set.
---------- BEGIN SOURCE ----------
public class BitSetGet {
public static void main(String[] args) {
BitSet bitSet = new BitSet();
bitSet.set(Integer.MAX_VALUE);
bitSet.set(999);
BitSet result = bitSet.get(0,1000);
System.out.println(result.length());
System.out.println(result.size());
System.out.println(result.get(999));
}
}
---------- END SOURCE ----------
CUSTOMER SUBMITTED WORKAROUND :
Clients can manually obtain the value of the bits using the get(int) method repeatedly.
Suggested fix: After assigning the output of length() to len, check if len < 0. If so, set len to Integer.MAX VALUE.
int len = length(); // (*)
if ( len < 0 ) len = Integer.MAX_VALUE;
This prevents the len <= fromIndex check being an issue.
Lowering the length also does not affect the bits that can be accessed by this function. toIndex already cannot be higher than Integer.MAX VALUE, so the Integer.MAX VALUE bit was already inaccessible in this get() function.
FREQUENCY : always
            
When the Integer.MAX VALUE bit is set, the get(int, int) function always returns a BitSet of size 0.
This is because length() overflows when Integer.MAX VALUE is set and so returns Integer.MIN VALUE.
public BitSet get(int fromIndex, int toIndex) {
checkRange(fromIndex, toIndex);
checkInvariants();
int len = length(); // (*)
// If no set bits in range return empty bitset
if (len <= fromIndex || fromIndex == toIndex)
return new BitSet(0);
...
When the comparison len <= fromIndex is done, this always evaluates to true regardless of the value of fromIndex, and as such the function returns BitSet(0).
STEPS TO FOLLOW TO REPRODUCE THE PROBLEM :
Create a BitSet with the default constructor, and set the Integer.MAX VALUE bit. Next, set bit 999.
Then do BitSet.get(0, 1000).
EXPECTED VERSUS ACTUAL BEHAVIOR :
EXPECTED -
A BitSet is returned with length = 1000 and size = 1024. In the resulting BitSet, the bit with index 999 is set.
ACTUAL -
A BitSet is returned with length and size = 0. The bit with index 999 is not set.
---------- BEGIN SOURCE ----------
public class BitSetGet {
public static void main(String[] args) {
BitSet bitSet = new BitSet();
bitSet.set(Integer.MAX_VALUE);
bitSet.set(999);
BitSet result = bitSet.get(0,1000);
System.out.println(result.length());
System.out.println(result.size());
System.out.println(result.get(999));
}
}
---------- END SOURCE ----------
CUSTOMER SUBMITTED WORKAROUND :
Clients can manually obtain the value of the bits using the get(int) method repeatedly.
Suggested fix: After assigning the output of length() to len, check if len < 0. If so, set len to Integer.MAX VALUE.
int len = length(); // (*)
if ( len < 0 ) len = Integer.MAX_VALUE;
This prevents the len <= fromIndex check being an issue.
Lowering the length also does not affect the bits that can be accessed by this function. toIndex already cannot be higher than Integer.MAX VALUE, so the Integer.MAX VALUE bit was already inaccessible in this get() function.
FREQUENCY : always
- csr for
- 
                    JDK-8307539 BitSet.get(int, int) always returns the empty BitSet when the Integer.MAX VALUE is set -           
- Draft
 
-         
- csr of
- 
                    JDK-8307539 BitSet.get(int, int) always returns the empty BitSet when the Integer.MAX VALUE is set -           
- Draft
 
-         
- relates to
- 
                    JDK-4213570 java.util.BitSet.size() is not 100% backward-compatible from 1.2 to 1.1.x -           
- Closed
 
-         
- 
                    JDK-8230557 wrong number of bits of space in use returned when BitSet#size() is called -           
- Closed
 
-         
- links to
- 
                     Review
        openjdk/jdk/13388 Review
        openjdk/jdk/13388