From c7d102070b3e22e21a55b696d799f7a7f73ffd6d Mon Sep 17 00:00:00 2001 From: Serguei Spitsyn Date: Mon, 25 Mar 2019 19:16:58 -0700 Subject: [PATCH] 8146986: JDI: Signature lookups for unprepared classes can take a long time Do not cache classes if signature is not provided Reviewed-by: sspitsyn, jcbeyler --- .../com/sun/tools/jdi/VirtualMachineImpl.java | 21 +++++++++---------- 1 file changed, 10 insertions(+), 11 deletions(-) diff --git a/src/jdk.jdi/share/classes/com/sun/tools/jdi/VirtualMachineImpl.java b/src/jdk.jdi/share/classes/com/sun/tools/jdi/VirtualMachineImpl.java index a8baf8cc2ff..50ba9d33e88 100644 --- a/src/jdk.jdi/share/classes/com/sun/tools/jdi/VirtualMachineImpl.java +++ b/src/jdk.jdi/share/classes/com/sun/tools/jdi/VirtualMachineImpl.java @@ -33,10 +33,11 @@ import java.util.ArrayList; import java.util.Arrays; import java.util.Collections; import java.util.HashMap; +import java.util.HashSet; import java.util.Iterator; import java.util.List; import java.util.Map; -import java.util.TreeSet; +import java.util.Set; import com.sun.jdi.BooleanType; import com.sun.jdi.BooleanValue; @@ -110,7 +111,7 @@ class VirtualMachineImpl extends MirrorImpl // tested unsynchronized (since once true, it stays true), but must // be set synchronously private Map typesByID; - private TreeSet typesBySignature; + private Set typesBySignature; private boolean retrievedAllTypes = false; private Map modulesByID; @@ -843,14 +844,9 @@ class VirtualMachineImpl extends MirrorImpl throw new InternalException("Invalid reference type tag"); } - /* - * If a signature was specified, make sure to set it ASAP, to - * prevent any needless JDWP command to retrieve it. (for example, - * typesBySignature.add needs the signature, to maintain proper - * ordering. - */ - if (signature != null) { - type.setSignature(signature); + if (signature == null && retrievedAllTypes) { + // do not cache if signature is not provided + return type; } typesByID.put(id, type); @@ -920,7 +916,7 @@ class VirtualMachineImpl extends MirrorImpl private void initReferenceTypes() { typesByID = new HashMap<>(300); - typesBySignature = new TreeSet<>(); + typesBySignature = new HashSet<>(); } ReferenceTypeImpl referenceType(long ref, byte tag) { @@ -969,6 +965,9 @@ class VirtualMachineImpl extends MirrorImpl if (retType == null) { retType = addReferenceType(id, tag, signature); } + if (signature != null) { + retType.setSignature(signature); + } } return retType; }