Fix PriorityQueue constructor to throw IllegalArgumentException if you pass Integer.MAX_VALUE as maxSize (thanks rsaavedraf)

This commit is contained in:
Mike McCandless 2018-06-28 12:11:18 -04:00
parent ab666ff9cf
commit 4c646dab3f
2 changed files with 18 additions and 5 deletions

View File

@ -50,14 +50,15 @@ public abstract class PriorityQueue<T> implements Iterable<T> {
// We allocate 1 extra to avoid if statement in top() // We allocate 1 extra to avoid if statement in top()
heapSize = 2; heapSize = 2;
} else { } else {
if ((maxSize < 0) || (maxSize >= ArrayUtil.MAX_ARRAY_LENGTH)) {
// Throw exception to prevent confusing OOME:
throw new IllegalArgumentException("maxSize must be >= 0 and < " + (ArrayUtil.MAX_ARRAY_LENGTH) + "; got: " + maxSize);
}
// NOTE: we add +1 because all access to heap is // NOTE: we add +1 because all access to heap is
// 1-based not 0-based. heap[0] is unused. // 1-based not 0-based. heap[0] is unused.
heapSize = maxSize + 1; heapSize = maxSize + 1;
if (heapSize > ArrayUtil.MAX_ARRAY_LENGTH) {
// Throw exception to prevent confusing OOME:
throw new IllegalArgumentException("maxSize must be <= " + (ArrayUtil.MAX_ARRAY_LENGTH-1) + "; got: " + maxSize);
}
} }
// T is unbounded type, so this unchecked cast works always: // T is unbounded type, so this unchecked cast works always:
@SuppressWarnings("unchecked") final T[] h = (T[]) new Object[heapSize]; @SuppressWarnings("unchecked") final T[] h = (T[]) new Object[heapSize];

View File

@ -252,4 +252,16 @@ public class TestPriorityQueue extends LuceneTestCase {
assertEquals(expected, actual); assertEquals(expected, actual);
} }
} }
public void testMaxIntSize() {
expectThrows(IllegalArgumentException.class, () -> {
new PriorityQueue<Boolean>(Integer.MAX_VALUE) {
@Override
public boolean lessThan(Boolean a, Boolean b) {
// uncalled
return true;
}
};
});
}
} }