为什么使用javac和gradle构建的相同代码表现不同?

时间:2017-04-02 15:49:59

标签: java gradle

switch (readChoice()) {
  //options
}

private static int readChoice() {
    String input;
    int choice = -1;
    try {
        input = scanner.next();
        choice = Integer.parseInt(input);
    } catch (NumberFormatException e) {
        logger.error("Error while trying to read choice from the console", e);
        }
    }
    return choice;

}

当我使用javac构建此代码时,一切正常。但是当我尝试运行使用gradle构建的代码时,我得到了这个

Exception in thread "main" java.util.NoSuchElementException
    at java.util.Scanner.throwFor(Scanner.java:862)
    at java.util.Scanner.next(Scanner.java:1371)
    at edu.java.core.cinema.Main.readChoice(Main.java:207)
    at edu.java.core.cinema.Main.main(Main.java:42)

42 - 有开关,207 - 有scanner.next()。 当没有东西要读时,扫描仪会尝试读取选择。 我刚开始学习gradle,所以也许我错了建筑。 我用gradle包装器构建并运行项目

$ gradle wrapper --gradle-version 3.4
$ ./gradlew build
$ ./gradlew run

更新: 有build.gradle文件

apply plugin: 'idea'
apply plugin: 'java'
apply plugin: 'application'

mainClassName = 'edu.java.core.cinema.Main'

repositories {
    mavenCentral()
}

jar {
    baseName = 'lab2'
    version =  '0.1.0'
}

sourceSets.main.java.srcDirs = ["src"]

sourceCompatibility = 1.8
targetCompatibility = 1.8

dependencies {
   compile group: 'com.google.code.gson', name: 'gson', version: '2.8.0'

   compile group: 'ch.qos.logback', name: 'logback-classic', version: '1.2.2'

   compile group: 'ch.qos.logback', name: 'logback-core', version: '1.2.2'

   compile group: 'org.slf4j', name: 'slf4j-api', version: '1.7.25'

}

1 个答案:

答案 0 :(得分:3)

在您的gradle构建文件中添加

run {
    standardInput = System.in
}

重定向" gradle输入"到system.in。如果你不是空的,那么在尝试阅读输入时会失败。