我的Java代码中不断出现NoSuchElement异常。我的代码出了什么问题?

时间:2014-06-23 04:59:55

标签: java eclipse recursion fibonacci nosuchelementexception

My Java 1.7程序执行各种数学函数。我已将函数分离为方法,它们可以自行运行。我还提出了一个提示方法,询问用户是否要继续。但是,输入数字后我继续收到NoSuchElement异常。 “再次尝试?(n / y)”打印,但它不会自动等待用户输入和错误。 Eclipse Luna强调了这一行:

String response = scanner.next();

这是主要方法:

public static void main(String[] args) {
    Scanner scanner = new Scanner(System.in);
    while (true) {
        System.out.print("Please input a number: ");
        int x = scanner.nextInt();
        System.out.println(chooseOperation(x));
        do_Continue();
        if (do_Continue() == false) {
            break;
        }
    }
    scanner.close();
}

这是操作选择器方法:

public static int chooseOperation(int n) {
    Scanner scanner = new Scanner(System.in);
    System.out.print("Factorial, Fibonacci, or Pisano? ");
    String response = scanner.next();
    scanner.close();
    if (response.equalsIgnoreCase("factorial")) {
        return factorial(n);
    } else if (response.equalsIgnoreCase("fibonacci")) {
        return fibonacci(n);
    } else if (response.equalsIgnoreCase("pisano")) {
        return pisano(n);
    } else {
        System.out.print("Invalid response. ");
        chooseOperation(n);
        return n;
    }
}

这是提示方法:

public static boolean do_Continue() {
    Scanner scanner = new Scanner(System.in);
    System.out.print("Try again? (n/y): ");
    String response = scanner.next();
    scanner.close();
    if (response.equalsIgnoreCase("n")) {
        return false;
    } else if (response.equalsIgnoreCase("y")){
        return true;
    } else {
        System.out.print("Invalid response. ");
        do_Continue();
    }
    return false;
}

如果这有帮助,以下是数学函数的方法:

public static int factorial(int n) {
    if (n==1 || n==0) {
        return 1;
    } else {
        return n*factorial(n-1);
    }
}

public static int fibonacci(int n) {
    if (n==1 || n==0) {
        return n;
    } else {
        return fibonacci(n-1) + fibonacci(n-2);
    }
}

public static int pisano(int n) {
    if (n==1 || n==0) {
        return n;
    } else {
        return (fibonacci(n-1) + fibonacci(n-2)) % 7;
    }
}

正如您所看到的,除了main方法之外,我的所有方法都是递归的。 谢谢! :)

1 个答案:

答案 0 :(得分:2)

不要打电话

scanner.close();

当你这样做时,你close() System.in!然后,当您尝试构建new Scanner(System.in);时,它无法正常工作(因为System.in已关闭)。