RFR 8187222 : ClassLoader.getSystemClassLoader not clear if recursive initialization leads to ISE or unspecified error (original) (raw)

Alan Bateman Alan.Bateman at oracle.com
Fri Dec 1 10:32:56 UTC 2017


On 30/11/2017 22:57, mandy chung wrote:

:

This is indeed a bug that should throw ISE when ClassLoader.getSystemClassLoader is called during the initialization of the system class loader, as the spec states. line 1921: I suggest to revise the message to make it clearer: "getSystemClassLoader cannot be called during the system class loader instantiation" In ClassLoader::initSystemClassLoader (line 1971), when the exception is thrown via Constructor::newInstance, it would be good to the cause of an InvocationTargetException like: +                Throwable t = e; +                if (e instanceof InvocationTargetException) { +                    t = e.getCause(); +                } +                throw new Error(t.getMessage(), t); Better still might be for initSystemClassLoader to re-throw the cause so that it appears immediately after the "Error occurred during initialization of VM" message that the VM will fail with.

-Alan



More information about the core-libs-dev mailing list