Details
-
Enhancement
-
Resolution: Fixed
-
P3
-
None
-
b86
Backports
Issue | Fix Version | Assignee | Priority | Status | Resolution | Resolved In Build |
---|---|---|---|---|---|---|
JDK-8142148 | emb-9 | Paul Sandoz | P3 | Resolved | Fixed | team |
JDK-8227947 | openjdk8u232 | Andrew Hughes | P3 | Resolved | Fixed | b01 |
JDK-8227797 | openjdk8u222 | Andrew Hughes | P3 | Resolved | Fixed | b09 |
JDK-8227908 | openjdk7u | Andrew Hughes | P3 | Resolved | Fixed | master |
Description
For use-cases see the classes java.lang.String, java.lang.AbstractStringBuilder, java.util.Arrays, java.util.Spliterators, and java.nio.Buffer.
Such checks, while not difficult, are often easy to get wrong and optimize correctly, thus there is a risk to the integrity and security of the runtime. It is desirable to locate such functionality in one place, methods in java.util.Arrays, rather than duplicate it in many places.
Three check methods have been identified:
1) Checking whether an index is within bounds
public static int check(int index, int length) {
if (length < 0 || index < 0 || index >= length) throw ...
return index;
}
2) Checking whether an absolute range is within bounds:
public static int checkStartEndRange(int start, int end, int length) {
if (start < 0 || start > end || end > length) throw ...
return start;
}
3) Checking whether a relative range is within bounds:
public static int checkOffsetSizeRange(int offset, int size, int length) {
if ((length | offset | size) < 0 || size > length - offset) throw ...
return offset;
}
An additional argument to the methods will be required that accepts a functional interface that in turn accepts or captures the arguments and returns an exception, likely extending from IndexOutOfBoundsException, with an appropriate exception message.
It's possible to model all existing exception reporting use-cases with:
Supplier<RuntimeException>
However, this will require that the caller capture the argument parameters if such values are to determine the exception type (such as IllegalArgumentException and ArrayIndexOutOfBoundsException, see java.util.Arrays) and exception messages.
The cost of capture, which requires an allocation-per-call, may be considered too high especially if performed in a loop. Such costs might be mitigated with escape analysis, but the conditions in which it can be reliably applied might be considered too fragile.
A second alternative is to leverage:
BiFunction<Integer, Integer, RuntimeException>
to support two out of three possible arguments. Many existing use-cases can be supported (although the existing use-case of java.lang.AbstractStringBuilder cannot be supported and capturing the unreported argument would be required or an exception message would require changing).
A third alternative is to define a custom functional interface e.g.:
interface RangeExceptionFunction {
RuntimeException apply(long indexStartOrOffset, long endSizeOrLength, long length)
}
The apply method declares long parameter types as this interface is reusable for any future check methods that accept long values.
For generic interfaces the runtime boxing cost is not considered an issue as such boxing will occur on the exception throwing path. However, the increased size of the method due to boxing conversion calls (invokestatic of Integer.valueOf per argument) and the cast of the return value (checkcast RuntimeException) might contribute to poor inlining effects. Note that a specific method declared with long parameter types also have an increased cost when called with int values due to conversion (i2l).
A further desire for such methods is some or all can be made intrinsic (see
Attachments
Issue Links
- backported by
-
JDK-8142148 Add utility methods to check indexes and ranges
- Resolved
-
JDK-8227797 Add utility methods to check indexes and ranges
- Resolved
-
JDK-8227908 Add utility methods to check indexes and ranges
- Resolved
-
JDK-8227947 Add utility methods to check indexes and ranges
- Resolved
- blocks
-
JDK-8135250 Replace custom crypto check/range functionality with check index/range methods in java.util.Objects
- Resolved
-
JDK-8042997 Make intrinsic some or all check index/range methods
- Resolved
- relates to
-
JDK-8142493 Utility methods to check indexes and ranges doesn't specify behavior when function produces null
- Closed
-
JDK-8206932 Add utility methods to check machine word indexes and ranges
- New
-
JDK-8080588 VarHandles development
- Resolved
-
JDK-8146458 Improve exception reporting for Objects.checkIndex/checkFromToIndex/checkFromIndexSize
- Resolved