Reputation: 753
I have a constructor that fails on the first call to new
because an Exception of class javax.persistence.NoResultException
being catch in one of the Class' methods.
EDIT: It was not a NoResultException, the NoResultException was the message of the Exception. The stackTrace is below
If I remove the import to javax.persistence.NoResultException
and catch just a generic Exception e
, the code works.
My questions are:
ClassNotFoundException
according to JavaDoc.that catch for javax.persistence.NoResultException as well as the import are old code which managed to survive between versions, I removed it and it's fixed, however I'd like to now the reason behind this.
STACKTRACE:
java.lang.NoClassDefFoundError: javax/persistence/NoResultException
at xxx.xxxxxx.xxxxxxx.xxxx.xxxx.xxxxxxxxxxxx.xxxxxxxxxxxxxxx(ClassB.java)
...
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
at java.util.concurrent.FutureTask.run(FutureTask.java:138)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:619)
Caused by: java.lang.ClassNotFoundException: javax.persistence.NoResultException
at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:252)
at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
... 10 more
Go to the end to see the step by step images of the debugger and the moment it fails
FAILING CODE:
// ClassB.java
import javax.persistence.NoResultException; // NOTICE THE IMPORT
public ClassB{
private UserInfo user;
private WebServiceBDelegate port;
private Connection conn;
public ClassB (UserInfo user, Connection conn) throws Exception {
System.out.println("CLASS B CONSTRUCTOR");
this.user = user;
this.conn = conn;
this.port = new WebServiceBService().getForwardingPort();
}
public boolean methodB(List<String> list){
try{
// Check some stuff on database using this.conn
} catch(NoResultException nre){ // NOTICE THE CATCH
String something = getSomething();
}
// Get the values to invoke SOAP service using this.conn
status = port.operationB(values);
if(status > 0)
return true;
return false;
}
}
WORKING CODE:
// ClassB.java
public ClassB{
private UserInfo user;
private WebServiceBDelegate port;
private Connection conn;
public ClassB (UserInfo user, Connection conn) throws Exception {
System.out.println("CLASS B CONSTRUCTOR");
this.user = user;
this.conn = conn;
this.port = new WebServiceBService().getForwardingPort();
}
public boolean methodB(List<String> list){
try{
// Check some stuff on database using this.conn
} catch(Exception e){ // THIS IS THE CHANGED CATCH
String something = getSomething();
}
// Get the values to invoke SOAP service using this.conn
status = port.operationB(values);
if(status > 0)
return true;
return false;
}
}
Here are the step by step images from the debugger when entering INTO the class constructor, to the JVM default ClassLoader and the moment it fails:
STEP INTO when calling new ClassB gets me to loadClassInternal(String)
STEP INTO loadClassInternal(String), gets me to loadClass(String,boolean)
STEP INTO loadClass(String,boolean), as far as I can get, now STEP RETURN
STEP RETURN gets me to loadClass(String)
STEP OVER gets me to loadClassInternal(String)
STEP OVER gives me javax.persistence.NoResultException
STEP OVER TAKES ME BACK TO A FINALLY IN MY CODE AND ENDS EXECUTION
Upvotes: 0
Views: 2433
Reputation: 17769
Upvotes: 2