JDK-6857789 : (reflect) Create common superclass of reflective exceptions
  • Type: Bug
  • Component: core-libs
  • Sub-Component: java.lang:reflect
  • Affected Version: 5.0,6,7
  • Priority: P3
  • Status: Resolved
  • Resolution: Fixed
  • OS: generic,windows_xp
  • CPU: generic,x86
  • Submitted: 2009-07-07
  • Updated: 2017-05-16
  • Resolved: 2009-07-31
The Version table provides details related to the release that this issue/RFE will be addressed.

Unresolved : Release in which this issue/RFE will be addressed.
Resolved: Release in which this issue/RFE has been resolved.
Fixed : Release in which this issue/RFE has been fixed. The release containing this fix may be available for download as an Early Access Release or a General Availability Release.

To download the current JDK release, click here.
JDK 7
7 b68Fixed
Related Reports
Duplicate :  
Relates :  
Description
There are at least a half dozen semantically related checked exceptions thrown by methods in the core reflection classes, java.lang.Class and java.lang.reflect.*:

java.lang.NoSuchMethodException
java.lang.NoSuchFieldException
java.lang.ClassNotFoundException
java.lang.InstantiationException
java.lang.IllegalAccessException
java.lang.reflect.InvocationTargetException

Programming using reflection would be more convenient if there was a common superclass more specific than Exception so that all these conditions could be caught with one catch block.

Comments
SUGGESTED FIX # http://hg.openjdk.java.net/jdk7/tl/jdk/rev/aaf0cb20646e # HG changeset patch # User darcy # Date 1247684935 25200 # Node ID aaf0cb20646e4519dc7ca10e869f37b91d353f1c # Parent beb5e5cad3aeefc21fee597eefe74458a15d3076 6857789: (reflect) Create common superclass of reflective exceptions Reviewed-by: martin --- a/src/share/classes/java/lang/ClassNotFoundException.java Mon Jul 13 15:14:17 2009 -0700 +++ b/src/share/classes/java/lang/ClassNotFoundException.java Wed Jul 15 12:08:55 2009 -0700 @@ -50,7 +50,7 @@ package java.lang; * @see java.lang.ClassLoader#loadClass(java.lang.String, boolean) * @since JDK1.0 */ -public class ClassNotFoundException extends Exception { +public class ClassNotFoundException extends ReflectiveOperationException { /** * use serialVersionUID from JDK 1.1.X for interoperability */ --- a/src/share/classes/java/lang/IllegalAccessException.java Mon Jul 13 15:14:17 2009 -0700 +++ b/src/share/classes/java/lang/IllegalAccessException.java Wed Jul 15 12:08:55 2009 -0700 @@ -56,7 +56,7 @@ package java.lang; * @see java.lang.reflect.Constructor#newInstance(Object[]) * @since JDK1.0 */ -public class IllegalAccessException extends Exception { +public class IllegalAccessException extends ReflectiveOperationException { private static final long serialVersionUID = 6616958222490762034L; /** --- a/src/share/classes/java/lang/InstantiationException.java Mon Jul 13 15:14:17 2009 -0700 +++ b/src/share/classes/java/lang/InstantiationException.java Wed Jul 15 12:08:55 2009 -0700 @@ -43,7 +43,7 @@ package java.lang; * @since JDK1.0 */ public -class InstantiationException extends Exception { +class InstantiationException extends ReflectiveOperationException { private static final long serialVersionUID = -8441929162975509110L; /** --- a/src/share/classes/java/lang/NoSuchFieldException.java Mon Jul 13 15:14:17 2009 -0700 +++ b/src/share/classes/java/lang/NoSuchFieldException.java Wed Jul 15 12:08:55 2009 -0700 @@ -31,7 +31,7 @@ package java.lang; * @author unascribed * @since JDK1.1 */ -public class NoSuchFieldException extends Exception { +public class NoSuchFieldException extends ReflectiveOperationException { private static final long serialVersionUID = -6143714805279938260L; /** --- a/src/share/classes/java/lang/NoSuchMethodException.java Mon Jul 13 15:14:17 2009 -0700 +++ b/src/share/classes/java/lang/NoSuchMethodException.java Wed Jul 15 12:08:55 2009 -0700 @@ -32,7 +32,7 @@ package java.lang; * @since JDK1.0 */ public -class NoSuchMethodException extends Exception { +class NoSuchMethodException extends ReflectiveOperationException { private static final long serialVersionUID = 5034388446362600923L; /** --- a/src/share/classes/java/lang/reflect/InvocationTargetException.java Mon Jul 13 15:14:17 2009 -0700 +++ b/src/share/classes/java/lang/reflect/InvocationTargetException.java Wed Jul 15 12:08:55 2009 -0700 @@ -39,7 +39,7 @@ package java.lang.reflect; * @see Method * @see Constructor */ -public class InvocationTargetException extends Exception { +public class InvocationTargetException extends ReflectiveOperationException { /** * Use serialVersionUID from JDK 1.1.X for interoperability */ --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/share/classes/java/lang/ReflectiveOperationException.java Wed Jul 15 12:08:55 2009 -0700 @@ -0,0 +1,91 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Sun designates this + * particular file as subject to the "Classpath" exception as provided + * by Sun in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +package java.lang; + +/** + * Common superclass of exceptions thrown by reflective operations in + * core reflection. + * + * @see LinkageError + * @since 1.7 + */ +public class ReflectiveOperationException extends Exception { + static final long serialVersionUID = 123456789L; + + /** + * Constructs a new exception with {@code null} as its detail + * message. The cause is not initialized, and may subsequently be + * initialized by a call to {@link #initCause}. + */ + public ReflectiveOperationException() { + super(); + } + + /** + * Constructs a new exception with the specified detail message. + * The cause is not initialized, and may subsequently be + * initialized by a call to {@link #initCause}. + * + * @param message the detail message. The detail message is saved for + * later retrieval by the {@link #getMessage()} method. + */ + public ReflectiveOperationException(String message) { + super(message); + } + + /** + * Constructs a new exception with the specified detail message + * and cause. + * + * <p>Note that the detail message associated with + * {@code cause} is <em>not</em> automatically incorporated in + * this exception's detail message. + * + * @param message the detail message (which is saved for later retrieval + * by the {@link #getMessage()} method). + * @param cause the cause (which is saved for later retrieval by the + * {@link #getCause()} method). (A {@code null} value is + * permitted, and indicates that the cause is nonexistent or + * unknown.) + */ + public ReflectiveOperationException(String message, Throwable cause) { + super(message, cause); + } + + /** + * Constructs a new exception with the specified cause and a detail + * message of {@code (cause==null ? null : cause.toString())} (which + * typically contains the class and detail message of {@code cause}). + * + * @param cause the cause (which is saved for later retrieval by the + * {@link #getCause()} method). (A {@code null} value is + * permitted, and indicates that the cause is nonexistent or + * unknown.) + */ + public ReflectiveOperationException(Throwable cause) { + super(cause); + } +}
15-07-2009

EVALUATION A fine idea.
07-07-2009