Preview: JDK-8055854 Examine overhead in java.net.URLClassLoader (stack-less exceptions)

Peter Levart peter.levart at gmail.com
Thu Oct 16 07:35:39 UTC 2014


On 10/16/2014 01:49 AM, Stanimir Simeonoff wrote:
> First, really nice tests.
>
> As for hiding: missing the real classloader impl. might be quite a bumper
> for some middleware implementations. That would make pretty hard to trace
> dependency issues without explicit logging, the latter is usually available
> but still. Also it'd depend if the classloaders actually use
> super.findClass() or not.
> IMO, the option should be switchable via some system property.

With a little tweak, the message of the stack-less exception thrown from 
findClass() methods can be extended to include the classloader's runtime 
class name and this message can be inherited by a replacement stack-full 
exception. So the stack-trace would look like:

Exception in thread "main" java.lang.ClassNotFoundException: XXX (thrown 
by: sun.misc.Launcher$AppClassLoader)
     at java.lang.ClassLoader.loadClass(ClassLoader.java:366)
     at java.lang.Class.forName0(Native Method)
     at java.lang.Class.forName(Class.java:265)
     at Test.doIt(Test.java:7)
     at Test.main(Test.java:11)

Instead of what we have now:

Exception in thread "main" java.lang.ClassNotFoundException: XXX
     at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
     at java.lang.ClassLoader.loadClass(ClassLoader.java:426)
     at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:317)
     at java.lang.ClassLoader.loadClass(ClassLoader.java:359)
     at java.lang.Class.forName0(Native Method)
     at java.lang.Class.forName(Class.java:265)
     at Test.doIt(Test.java:7)
     at Test.main(Test.java:11)


Would this be enough to cover your concern?

Regards, Peter

>
> I am not sure about the need to hide the stackless c-tor as the effect can
> be achieved by overriding fillInStackTrace(); w/o the extra baggage of
> JavaLangAccess.
>
> Overall very decent improvement.
>
> Cheers
> Stanimir
>
>



More information about the core-libs-dev mailing list