请问如下java程序的错误 报Exception in thread "main" java.util.NoSuchElementException

importjava.util.*;publicclasscase_of_test{publicstaticvoidmain(String[]args){intkey=1... import java.util.*;
public class case_of_test {
public static void main(String[] args){
int key = 1;
while (key != 0){
Scanner input = new Scanner(System.in);
System.out.println("input option");
key = input.nextInt();
input.close();
switch (key) {
case 1:{System.out.println(key);break;}
case 2:{System.out.println(key);break;}
case 3:{System.out.println(key);break;}
case 0:break;
}
}

}
}
展开
 我来答
subirt
推荐于2016-07-19 · TA获得超过1876个赞
知道大有可为答主
回答量:2435
采纳率:0%
帮助的人:1255万
展开全部
//把Scanner对象的声明放在循环外面就好了
import java.util.*;
public class case_of_test {
    public static void main(String[] args){
Scanner input = new Scanner(System.in);
        do{
    System.out.println("input option");
    int key = input.nextInt();
    switch (key) {
        case 1:System.out.println(key);break;
        case 2:System.out.println(key);break;
        case 3:System.out.println(key);break;
        case 0:break;
    }
}while (key != 0);
input.close();

    }
}
追问
似乎是这个原因,请问为什么必须要这样呢?逻辑上说需要键入的时候new Scanner,接收了键入以后close似乎没什么错(下一个循环再new.close.)
星心点灯11
2014-10-27 · TA获得超过3737个赞
知道小有建树答主
回答量:1747
采纳率:0%
帮助的人:1122万
展开全部
把这行注释掉
//   input.close();
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友19f4c5b
2014-10-27
知道答主
回答量:66
采纳率:0%
帮助的人:25.4万
展开全部
去掉 input.close();
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
yugi111
2014-10-27 · TA获得超过8.1万个赞
知道大有可为答主
回答量:5.1万
采纳率:70%
帮助的人:1.3亿
展开全部
nextInt 下一个整形

你输入的类型不匹配
追问
int key = 1;

定义的key变量是整形。另外如果输入1的话,会打印“1”(第一次循序执行正常),然后打印第二次循环的"input option",然后报错。所以是否应该不是nextInt的问题吧?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
torichi
2014-10-27 · 超过37用户采纳过TA的回答
知道小有建树答主
回答量:139
采纳率:100%
帮助的人:79.8万
展开全部
你可以参考下面的:
public class case_of_test {
public static void main(String[] args){
int key = 1;
Scanner input = new Scanner(System.in);
while (key != 0){
System.out.println("input option");
key = input.nextInt();
switch (key) {
case 1:{System.out.println(key);break;}
case 2:{System.out.println(key);break;}
case 3:{System.out.println(key);break;}
case 0:break;
}
}
input.close();

}
}
更多追问追答
追问
测试OK,看来确实是Scanner声明和close的位置的问题。麻烦问一下原因是什么,为什么close放在主方法最后就没问题了?逻辑上说需要键入的时候new Scanner,接收了键入以后close似乎没什么错(下一个循环再new..)
追答
不好意思,刚看到追问,
因为你过早关闭输入流,截断了输入,读不进去所以才报错。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式