ClassNotFoundException我没有成功捕获

时间:2015-08-13 09:49:41

标签: java exception try-catch-finally

我在java中阅读了很多关于try / catch / finally过程的页面,但是我没有成功捕获代码中的ClassNotFoundException。我使用 for循环打开并以rdfxml格式保存我提供的目录中的每个文件作为参数。我想要的是当我执行代码时,我得到e.getmessage()并且循环继续处理下一个文件。

问题是我的脚本运行得很好,但是当发生ClassNotFoundException时我没有收到e.getmessage()。

@SuppressWarnings("finally")
public static void main(String[] args) {

    File dir = new File(args[0]);
    File[] directoryListing = dir.listFiles();

    if (directoryListing != null) {
        for (File owlFile : directoryListing){
            String name = owlFile.getName();
                    try {
                        translateOwlToRdfXml(owlFile,name);
                    }
                    catch (OWLOntologyCreationException|OWLOntologyStorageException|ClassNotFoundException e) {
                        System.out.println(name + " has not been saved into RDF/XML;");
                        System.out.println(e.getMessage());
                        }
                    finally {
                        continue;
                    }
                }

            }
        }


    static void translateOwlToRdfXml(File owlFile, String name) throws OWLOntologyCreationException, OWLOntologyStorageException, ClassNotFoundException {

            OWLOntologyManager manager = OWLManager.createOWLOntologyManager();

        System.out.println("Loaded ontology: " + name);
        OWLOntology ontology;
        ontology = manager.loadOntologyFromOntologyDocument(owlFile);
        RDFXMLOntologyFormat rdfxmlFormat = new RDFXMLOntologyFormat();

            manager.saveOntology(ontology, rdfxmlFormat, IRI.create(owlFile));
        System.out.println("Saved ontology in RDF/OWL: " + name);

    }
}

当我不写“finally”块时,我收到此消息:

Exception in thread "main" java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at org.eclipse.jdt.internal.jarinjarloader.JarRsrcLoader.main(JarRsrcLoader.java:58)
Caused by: java.lang.NoClassDefFoundError: com/github/jsonldjava/core/JsonLdError
    at org.openrdf.rio.jsonld.JSONLDParserFactory.getParser(JSONLDParserFactory.java:37)
    at org.openrdf.rio.Rio.createParser(Rio.java:195)
    at org.semanticweb.owlapi.rio.RioParserImpl.parseDocumentSource(RioParserImpl.java:241)
    at org.semanticweb.owlapi.rio.RioParserImpl.parse(RioParserImpl.java:191)
    at uk.ac.manchester.cs.owl.owlapi.ParsableOWLOntologyFactory.loadOWLOntology(ParsableOWLOntologyFactory.java:161)
    at uk.ac.manchester.cs.owl.owlapi.OWLOntologyManagerImpl.loadOntology(OWLOntologyManagerImpl.java:975)
    at uk.ac.manchester.cs.owl.owlapi.OWLOntologyManagerImpl.loadOntologyFromOntologyDocument(OWLOntologyManagerImpl.java:913)
    at uk.ac.manchester.cs.owl.owlapi.OWLOntologyManagerImpl.loadOntologyFromOntologyDocument(OWLOntologyManagerImpl.java:928)
    at owl2rdf.owl2rdf.translateOwlToRdfXml(owl2rdf.java:57)
    at owl2rdf.owl2rdf.main(owl2rdf.java:32)
    ... 5 more
Caused by: java.lang.ClassNotFoundException: com.github.jsonldjava.core.JsonLdError
    at java.net.URLClassLoader$1.run(URLClassLoader.java:372)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:360)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 15 more

但是当我写“finally”时,我什么也得不到,代码继续处理下一个文件。我以为我不清楚try / catch和throw方法是如何工作的。

提前致谢

3 个答案:

答案 0 :(得分:2)

您只能捕获您在catch(...)中列出的异常。堆栈跟踪显示main方法中的异常是NoClassDefFoundError。

解决它取代

catch (OWLOntologyCreationException|OWLOntologyStorageException|ClassNotFoundException e) {
      System.out.println(name + " has not been saved into RDF/XML;");
      System.out.println(e.getMessage());
}

通过(这里你捕获所有例外)

catch (Exception e) {
         System.out.println(name + " has not been saved into RDF/XML;");
         System.out.println(e.getMessage());
}

或者

catch (OWLOntologyCreationException|OWLOntologyStorageException
|ClassNotFoundException|NoClassDefFoundErrore) {
             System.out.println(name + " has not been saved into RDF/XML;");
             System.out.println(e.getMessage());
}

答案 1 :(得分:0)

尝试捕捉NoClassDefFoundError而不是ClassNotFoundException。后者由前者包裹。

请参阅以下堆栈跟踪片段 - 这意味着该方法将抛出NoClassDefFoundError

Caused by: java.lang.NoClassDefFoundError: com/github/jsonldjava/core/JsonLdError
at org.openrdf.rio.jsonld.JSONLDParserFactory.getParser(JSONLDParserFactory.java:37)
at org.openrdf.rio.Rio.createParser(Rio.java:195)
at org.semanticweb.owlapi.rio.RioParserImpl.parseDocumentSource(RioParserImpl.java:241)
at org.semanticweb.owlapi.rio.RioParserImpl.parse(RioParserImpl.java:191)
at uk.ac.manchester.cs.owl.owlapi.ParsableOWLOntologyFactory.loadOWLOntology(ParsableOWLOntologyFactory.java:161)
at uk.ac.manchester.cs.owl.owlapi.OWLOntologyManagerImpl.loadOntology(OWLOntologyManagerImpl.java:975)
at uk.ac.manchester.cs.owl.owlapi.OWLOntologyManagerImpl.loadOntologyFromOntologyDocument(OWLOntologyManagerImpl.java:913)
at uk.ac.manchester.cs.owl.owlapi.OWLOntologyManagerImpl.loadOntologyFromOntologyDocument(OWLOntologyManagerImpl.java:928)
at owl2rdf.owl2rdf.translateOwlToRdfXml(owl2rdf.java:57)

答案 2 :(得分:0)

translateOwlToRdfXml投掷InvocationTargetException

InvocationTargetException is a checked exception that wraps
an exception thrown by an invoked method or constructor.

您需要捕获此异常,然后使用getTargetException获取NoClassDefFoundError。从那里你可以得到getCause给你包装ClassNotFoundException