在终端Intellij Idea中运行jmh基准测试时发生DefaultChemObjectBuilder ClassNotFoundException

时间:2016-10-13 05:37:06

标签: maven intellij-idea java-8 jmh cdk

我可以使用main方法将项​​目作为IntelliJ IDEA中的应用程序运行。但是,当我尝试使用终端运行它来进行基准测试时,会发生一个未找到类的异常。

public class MyBenchmark {

@Benchmark
public static void sdfIterativeReader() throws ClassNotFoundException, FileNotFoundException {
    File sdfFile = new File("molecule.sdf");
    IChemObjectBuilder builder = DefaultChemObjectBuilder.getInstance();

    IteratingSDFReader reader = new IteratingSDFReader(new FileInputStream(sdfFile),builder);
    while (reader.hasNext()) {
        IAtomContainer molecule = (IAtomContainer) reader.next();
        IMolecularFormula formula = MolecularFormulaManipulator.getMolecularFormula(molecule);
        String molecularFromula = MolecularFormulaManipulator.getString(formula);
        System.out.println(molecularFromula);
    }
}

}

我使用了命令:mvn clean install然后项目正在成功构建。当我运行命令时:

  

java -jar target / benchmarks.jar

它出现以下错误:

enter image description here

在这里,我附上了pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.chemid</groupId>
<artifactId>chemid-benchmark</artifactId>
<version>1.0</version>
<packaging>jar</packaging>
<name>JMH benchmark sample: Java</name>
<prerequisites>
    <maven>3.0</maven>
</prerequisites>
<dependencies>
    <!-- https://mvnrepository.com/artifact/org.openjdk.jmh/jmh-generator-annprocess -->
    <dependency>
        <groupId>org.openjdk.jmh</groupId>
        <artifactId>jmh-core</artifactId>
        <version>${jmh.version}</version>
    </dependency>
    <dependency>
        <groupId>org.openjdk.jmh</groupId>
        <artifactId>jmh-generator-annprocess</artifactId>
        <version>${jmh.version}</version>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>cdk</groupId>
        <artifactId>cdk</artifactId>
        <version>1.5.13</version>
        <scope>system</scope>
        <systemPath>${cdk.lib}/cdk-1.5.13 .jar</systemPath>
    </dependency>
    <dependency>
        <groupId>net.sourceforge.streamsupport</groupId>
        <artifactId>streamsupport</artifactId>
        <version>1.5.1</version>
    </dependency>
    <dependency>
        <groupId>org.openscience.cdk</groupId>
        <artifactId>cdk-io</artifactId>
        <version>1.5.13</version>
    </dependency>
    <dependency>
        <groupId>org.openscience.cdk</groupId>
        <artifactId>cdk</artifactId>
        <version>1.5.13</version>
        <type>pom</type>
    </dependency>
    <dependency>
        <groupId>org.openscience.cdk</groupId>
        <artifactId>cdk-core</artifactId>
        <version>1.5.13</version>
    </dependency>
</dependencies>
<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.7</maven.compiler.source>
    <jmh.version>1.6.3</jmh.version>
    <javac.target>1.8</javac.target>
    <uberjar.name>benchmarks</uberjar.name>
    <cdk.lib>${basedir}/libs</cdk.lib>
</properties>
<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.1</version>
            <configuration>
                <compilerVersion>${javac.target}</compilerVersion>
                <source>${javac.target}</source>
                <target>${javac.target}</target>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-shade-plugin</artifactId>
            <version>2.4.3</version>
            <executions>
                <execution>
                    <phase>package</phase>
                    <goals>
                        <goal>shade</goal>
                    </goals>
                    <configuration>
                        <finalName>${uberjar.name}</finalName>
                        <transformers>
                            <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                <mainClass>org.openjdk.jmh.Main</mainClass>
                            </transformer>
                        </transformers>
                        <filters>
                            <filter>
                                <!--
                                    Shading signed JARs will fail without this.
                                    http://stackoverflow.com/questions/999489/invalid-signature-file-when-attempting-to-run-a-jar
                                -->
                                <artifact>*:*</artifact>
                                <excludes>
                                    <exclude>META-INF/*.SF</exclude>
                                    <exclude>META-INF/*.DSA</exclude>
                                    <exclude>META-INF/*.RSA</exclude>
                                </excludes>
                            </filter>
                        </filters>
                    </configuration>
                </execution>
            </executions>
        </plugin>
    </plugins>
    <pluginManagement>
        <plugins>
            <plugin>
                <artifactId>maven-clean-plugin</artifactId>
                <version>2.5</version>
            </plugin>
            <plugin>
                <artifactId>maven-deploy-plugin</artifactId>
                <version>2.8.1</version>
            </plugin>
            <plugin>
                <artifactId>maven-install-plugin</artifactId>
                <version>2.5.1</version>
            </plugin>
            <plugin>
                <artifactId>maven-jar-plugin</artifactId>
                <version>2.4</version>
            </plugin>
            <plugin>
                <artifactId>maven-javadoc-plugin</artifactId>
                <version>2.9.1</version>
            </plugin>
            <plugin>
                <artifactId>maven-resources-plugin</artifactId>
                <version>2.6</version>
            </plugin>
            <plugin>
                <artifactId>maven-site-plugin</artifactId>
                <version>3.3</version>
            </plugin>
            <plugin>
                <artifactId>maven-source-plugin</artifactId>
                <version>2.2.1</version>
            </plugin>
            <plugin>
                <artifactId>maven-surefire-plugin</artifactId>
                <version>2.17</version>
            </plugin>
        </plugins>
    </pluginManagement>
</build>

1 个答案:

答案 0 :(得分:1)

将此行添加到文件MANIFEST.MF

  

Class-Path:lib / cdk-1.5.13.jar

或者使用main方法运行基准思维课程:

  

java -cp path / to / cdk / lib / cdk-1.5.13.jar:。 com.your.main.ClassName

如需更多信息,请阅读this discussion的答案。

answer 用于了解您为system选择的Maven依赖关系的cdk-1.5.13.jar范围。