java - Android Studio 上 Kotlin(非 Android)项目的 ClassNotFoundException 错误

标签 java android-studio gradle kotlin

我尝试使用 Android Studio 2.3.3 创建一个普通的 Kotlin 项目(非安卓,只是桌面/命令行项目)。

我按照规定的步骤操作 here但有不同的 build.gradle 内容,我分享了其内容 here .

实际上 build.gradle 的内容是我在使用 IntelliJ Community Edition (2017.2) 生成新项目后从 build.gradle 文件中复制的。

然后我创建一个配置,以便能够在桌面上运行它,并进行适当的设置,例如主类、工作目录和模块的使用类路径。您可以在下图中看到。

enter image description here

下面是我的项目文件结构

enter image description here

然后我同步项目,它成功了。但是当我尝试运行 项目时出现错误。我收到以下错误。

    "/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/bin/java" -Didea.launcher.port=7534 "-Didea.launcher.bin.path=/Applications/Android Studio.app/Contents/bin" -Dfile.encoding=UTF-8 -classpath "/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/charsets.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/ext/cldrdata.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/ext/dnsns.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/ext/jaccess.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/ext/localedata.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/ext/nashorn.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/ext/sunec.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/ext/sunjce_provider.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/ext/sunpkcs11.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/ext/zipfs.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/jce.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/jsse.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/management-agent.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/resources.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/jre/lib/rt.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/lib/dt.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/lib/jconsole.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/lib/sa-jdi.jar:/Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/lib/tools.jar:/Users/haxpor/.gradle/caches/modules-2/files-2.1/org.jetbrains/annotations/13.0/919f0dfe192fb4e063e7dacadee7f8bb9a2672a9/annotations-13.0.jar:/Users/haxpor/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-stdlib-jre7/1.1.4-2/272a21c30432c943d618008fbbd34762eb0d6c8a/kotlin-stdlib-jre7-1.1.4-2.jar:/Users/haxpor/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-stdlib/1.1.4-2/fec983b2608a8a91a1b87dba18d247d692cf6b51/kotlin-stdlib-1.1.4-2.jar:/Users/haxpor/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-stdlib-jre8/1.1.4-2/168cc3f45c307edda6c867dd0635a7d451257551/kotlin-stdlib-jre8-1.1.4-2.jar:/Applications/Android Studio.app/Contents/lib/idea_rt.jar" com.intellij.rt.execution.application.AppMain io.wasin.testjavaapp.Main
Exception in thread "main" java.lang.ClassNotFoundException: io.wasin.testjavaapp.Main
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:264)
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:123)

Process finished with exit code 1

我看到上面提供的类路径参数 /Applications/Android Studio.app/Contents/jre/jdk/Contents/Home/bin/java 没有与我的项目相关的目录。我不知道如何通过 gradle 添加类路径目录,尽管我已经在配置中设置了它。

我该如何解决这个问题?

更新:

以下是我的Main.kt代码。这只是为了测试目的。所以只需打印一些东西。

package io.wasin.testjavaapp

object Main {
    @JvmStatic fun main(arg: Array<String>) {
        println("Hello world")
    }
}

我还为 Kotlin 版本更新了 build.gradle 以匹配 Android Studio 上的 Kotlin 插件版本。现在是 ext.kotlin_version = '1.1.4-2'。虽然还是没有解决问题。

更新 2

我在 src 目录的同一级别检查了 build 目录。那里没有生成/构建 .classintermediates 文件,只有 kotlin-build/caches/version.txt 就是这样。没有其他文件。所以问题可能是由于源文件根本没有编译?

更新 3

我尝试创建一个新模块以查看它是否是根本原因。还创建了 assets 文件夹作为工作目录,再次重新排列源文件夹如下。

enter image description here

我们现在有 2 个模块。

  1. testJavaApp - root
  2. desktop - 由 Main.kt 组成并用作桌面可执行文件

testJavaApp 有以下 build.gradle

代码
group 'io.wasin'
version '1.0-SNAPSHOT'

// Top-level build file where you can add configuration options common to 
all sub-projects/modules.
buildscript {
    ext.kotlin_version = '1.1.4-2'
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.3.3'
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

desktop 模块也有以下代码用于 build.gradle

apply plugin: 'kotlin'

sourceSets.main.java.srcDirs = [ "src/" ]
project.ext.mainClassName = "io.wasin.testjavaapp.Main"
project.ext.assetsDir = new File("../assets");

dependencies {
    testCompile group: 'junit', name: 'junit', version: '4.12'
    compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
}
repositories {
    mavenCentral()
}

task run(dependsOn: classes, type: JavaExec) {
    main = project.mainClassName
    classpath = sourceSets.main.runtimeClasspath
    standardInput = System.in
    workingDir = project.assetsDir
    ignoreExitValue = true
}

不幸的是,它仍然没有工作,并且出现了同样的错误。

更新 4

@aristotll 在评论中提供了信息,他使用 Android Studio 进行了测试并遇到了同样的问题,但使用 IntelliJ 时没有。他说这可能是 Android Studio 的错误。所以我想,我会再尝试几次,然后决定它是否足够可靠以报告为错误。感谢您抽出时间进行测试。

最佳答案

我也遇到过这个问题并解决了。

在build.gradle中添加runtimeClasspath files("build/classes/kotlin/main")

dependencies {
    // This dependency is found on compile classpath of this component and consumers.
    compile 'com.google.guava:guava:23.0'

    // Use JUnit test framework
    testCompile 'junit:junit:4.12'
    compile "org.jetbrains.kotlin:kotlin-stdlib-jdk8:$kotlin_version"
    compile group: 'dom4j', name: 'dom4j', version: '1.6.1'
    runtimeClasspath files("build/classes/kotlin/main")
}

因为 Android Studio 在 build/classes/kotlin/main 中找不到类。添加 runtimeClasspath 就可以了!

关于java - Android Studio 上 Kotlin(非 Android)项目的 ClassNotFoundException 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45891317/

相关文章:

java - Android Studio (1.5.1) -- 错误 : cannot find symbol class/App won't run

java - 使用 gradle 复制任务从所有依赖项复制 META-INF

Java 不同的可用堆大小

加载类时java运行时错误

java - 如何使用应用程序引擎中生成的默认ID

android-studio - 安装android应用程序时出错

java - 如果 Android API 级别低于 26,如何将存储访问框架与 MediaMuxer 一起使用

android - 如何自动将 ListView 字段的第一行传递给 EditText 字段

android - 无法从 Android Studio 生成签名的 APK "Execution failed for task ' :packageRelease'"

android - com.android.build.api.transform.TransformException : com. android.builder.packaging.DuplicateFileException: 重复文件