diff --git a/src/jdk.jdi/share/classes/com/sun/tools/jdi/ClassLoaderReferenceImpl.java b/src/jdk.jdi/share/classes/com/sun/tools/jdi/ClassLoaderReferenceImpl.java index 2e21e14f72b..1dd112bdbad 100644 --- a/src/jdk.jdi/share/classes/com/sun/tools/jdi/ClassLoaderReferenceImpl.java +++ b/src/jdk.jdi/share/classes/com/sun/tools/jdi/ClassLoaderReferenceImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -59,12 +59,12 @@ public class ClassLoaderReferenceImpl extends ObjectReferenceImpl public List definedClasses() { ArrayList definedClasses = new ArrayList<>(); - for (ReferenceType type : vm.allClasses()) { + vm.forEachClass(type -> { if (type.isPrepared() && - equals(type.classLoader())) { + equals(type.classLoader())) { definedClasses.add(type); } - } + }); return definedClasses; } diff --git a/src/jdk.jdi/share/classes/com/sun/tools/jdi/ClassTypeImpl.java b/src/jdk.jdi/share/classes/com/sun/tools/jdi/ClassTypeImpl.java index f458327a3c3..59936b1abc4 100644 --- a/src/jdk.jdi/share/classes/com/sun/tools/jdi/ClassTypeImpl.java +++ b/src/jdk.jdi/share/classes/com/sun/tools/jdi/ClassTypeImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -110,16 +110,15 @@ final public class ClassTypeImpl extends InvokableTypeImpl public List subclasses() { List subs = new ArrayList<>(); - for (ReferenceType refType : vm.allClasses()) { + vm.forEachClass(refType -> { if (refType instanceof ClassType) { ClassType clazz = (ClassType)refType; ClassType superclass = clazz.superclass(); if ((superclass != null) && superclass.equals(this)) { - subs.add((ClassType)refType); + subs.add(clazz); } } - } - + }); return subs; } diff --git a/src/jdk.jdi/share/classes/com/sun/tools/jdi/InterfaceTypeImpl.java b/src/jdk.jdi/share/classes/com/sun/tools/jdi/InterfaceTypeImpl.java index fefeac6e0bd..b543de0e9e5 100644 --- a/src/jdk.jdi/share/classes/com/sun/tools/jdi/InterfaceTypeImpl.java +++ b/src/jdk.jdi/share/classes/com/sun/tools/jdi/InterfaceTypeImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -77,27 +77,27 @@ final public class InterfaceTypeImpl extends InvokableTypeImpl public List subinterfaces() { List subs = new ArrayList(); - for (ReferenceType refType : vm.allClasses()) { + vm.forEachClass(refType -> { if (refType instanceof InterfaceType) { InterfaceType interfaze = (InterfaceType)refType; if (interfaze.isPrepared() && interfaze.superinterfaces().contains(this)) { subs.add(interfaze); } } - } + }); return subs; } public List implementors() { List implementors = new ArrayList(); - for (ReferenceType refType : vm.allClasses()) { + vm.forEachClass(refType -> { if (refType instanceof ClassType) { ClassType clazz = (ClassType)refType; if (clazz.isPrepared() && clazz.interfaces().contains(this)) { implementors.add(clazz); } } - } + }); return implementors; } diff --git a/src/jdk.jdi/share/classes/com/sun/tools/jdi/ReferenceTypeImpl.java b/src/jdk.jdi/share/classes/com/sun/tools/jdi/ReferenceTypeImpl.java index 80f0f81bdc9..ff443ae14c0 100644 --- a/src/jdk.jdi/share/classes/com/sun/tools/jdi/ReferenceTypeImpl.java +++ b/src/jdk.jdi/share/classes/com/sun/tools/jdi/ReferenceTypeImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -607,23 +607,20 @@ public abstract class ReferenceTypeImpl extends TypeImpl implements ReferenceTyp } public List nestedTypes() { - List all = vm.allClasses(); List nested = new ArrayList(); String outername = name(); int outerlen = outername.length(); - Iterator iter = all.iterator(); - while (iter.hasNext()) { - ReferenceType refType = iter.next(); + vm.forEachClass(refType -> { String name = refType.name(); int len = name.length(); /* The separator is historically '$' but could also be '#' */ if ( len > outerlen && name.startsWith(outername) ) { char c = name.charAt(outerlen); - if ( c =='$' || c== '#' ) { + if ( c == '$' || c == '#' ) { nested.add(refType); } } - } + }); return nested; } 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 50ba9d33e88..254b5847d43 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 @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -38,6 +38,7 @@ import java.util.Iterator; import java.util.List; import java.util.Map; import java.util.Set; +import java.util.function.Consumer; import com.sun.jdi.BooleanType; import com.sun.jdi.BooleanValue; @@ -57,6 +58,7 @@ import com.sun.jdi.InternalException; import com.sun.jdi.LongType; import com.sun.jdi.LongValue; import com.sun.jdi.ModuleReference; +import com.sun.jdi.ObjectCollectedException; import com.sun.jdi.PathSearchingVirtualMachine; import com.sun.jdi.PrimitiveType; import com.sun.jdi.ReferenceType; @@ -338,6 +340,27 @@ class VirtualMachineImpl extends MirrorImpl return Collections.unmodifiableList(a); } + /** + * Performs an action for each loaded type. + */ + public void forEachClass(Consumer action) { + for (ReferenceType type : allClasses()) { + try { + action.accept(type); + } catch (ObjectCollectedException ex) { + // Some classes might be unloaded and garbage collected since + // we retrieved the copy of all loaded classes and started + // iterating over them. In this case calling methods on such types + // might result in com.sun.jdi.ObjectCollectedException + // being thrown. We ignore such classes and keep iterating. + if ((vm.traceFlags & VirtualMachine.TRACE_OBJREFS) != 0) { + vm.printTrace("ObjectCollectedException was thrown while " + + "accessing unloaded class " + type.name()); + } + } + } + } + public void redefineClasses(Map classToBytes) {