diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Infer.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Infer.java index a88dcfa7dd4..1f1231b7f7a 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Infer.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Infer.java @@ -57,8 +57,7 @@ import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.EnumSet; -import java.util.HashMap; -import java.util.HashSet; +import java.util.LinkedHashMap; import java.util.LinkedHashSet; import java.util.Map; import java.util.Optional; @@ -1264,7 +1263,7 @@ public class Infer { } /** an incorporation cache keeps track of all executed incorporation-related operations */ - Map incorporationCache = new HashMap<>(); + Map incorporationCache = new LinkedHashMap<>(); protected static class BoundFilter implements Predicate { @@ -1426,7 +1425,7 @@ public class Infer { } /** cache used to avoid redundant computation of tree costs */ - final Map, Integer>> treeCache = new HashMap<>(); + final Map, Integer>> treeCache = new LinkedHashMap<>(); /** constant value used to mark non-existent paths */ final Pair, Integer> noPath = new Pair<>(null, Integer.MAX_VALUE); @@ -1754,7 +1753,7 @@ public class Infer { * through all its dependencies. */ protected Set closure() { - Set closure = new HashSet<>(); + Set closure = new LinkedHashSet<>(); closureInternal(closure); return closure; } diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/InferenceContext.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/InferenceContext.java index c47fb9b23a7..2fec365aff5 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/InferenceContext.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/InferenceContext.java @@ -27,7 +27,6 @@ package com.sun.tools.javac.comp; import java.util.Collections; import java.util.EnumSet; -import java.util.HashMap; import java.util.LinkedHashMap; import java.util.LinkedHashSet; import java.util.Map; @@ -551,7 +550,7 @@ public class InferenceContext { * This is why the tree is used as the key of the map below. This map * stores a Type per AST. */ - Map captureTypeCache = new HashMap<>(); + Map captureTypeCache = new LinkedHashMap<>(); Type cachedCapture(JCTree tree, Type t, boolean readOnly) { Type captured = captureTypeCache.get(tree);