RFR: 8282662: Use List/Set.of() factory methods to reduce memory consumption
liach
duke at openjdk.java.net
Tue Mar 8 14:35:12 UTC 2022
On Mon, 7 Mar 2022 15:11:50 GMT, Сергей Цыпанов <duke at openjdk.java.net> wrote:
> `List.of()` along with `Set.of()` create unmodifiable `List/Set` but with smaller footprint comparing to `Arrays.asList()` / `new HashSet()` when called with vararg of size 0, 1, 2.
>
> In general replacement of `Arrays.asList()` with `List.of()` is dubious as the latter is null-hostile, however in some cases we are sure that arguments are non-null. Into this PR I've included the following cases (in addition to those where the argument is proved to be non-null at compile-time):
> - `MethodHandles.longestParameterList()` never returns null
> - parameter types are never null
> - interfaces used for proxy construction and returned from `Class.getInterfaces()` are never null
> - exceptions types of method signature are never null
Calling `Arrays.asList` vs `List.of` on a switch on the array length seems like an overkill for such a simple thing. Imo the safest changes are where we know the input array length is going to be 1 or 2.
src/java.base/share/classes/java/nio/file/FileTreeIterator.java line 70:
> 68: throws IOException
> 69: {
> 70: this.walker = new FileTreeWalker(List.of(options), maxDepth);
Relates to https://bugs.openjdk.java.net/browse/JDK-8145048
src/java.base/share/classes/sun/reflect/annotation/AnnotationSupport.java line 79:
> 77: containerBeforeContainee(annotations, annoClass);
> 78:
> 79: result.addAll((indirectFirst ? 0 : 1), List.of(indirect));
This `indirect` is most likely to be of size > 2
-------------
PR: https://git.openjdk.java.net/jdk/pull/7729
More information about the nio-dev
mailing list