dequantianhe 发表于 2021-9-7 12:58:34

try-catch语句可以用在while循环里嘛?

各位大神好,小弟又跑来学习java了,今天遇到一个问题:
利用while循环实现接收一个正确的年份,通过try-catch语句捕捉异常。
但奇怪的是,第一次报类型不匹配后,再次进入循环会跳过重新接收新数据的语句(红框中的),然后陷入死循环。
这个是为什么呢?


随后为了尝试解决,我怀疑是上一次scanner里接收的数据没有清空,被try-catch语句自动进行判定了,然后我进行了如下改进,
即把创建scanner的语句加入到了循环里,每次重新生成进行验证判断,结果还是不对,这次的表现为:
第一次赋值异常后,进入第二次循环,但到了try里面的接受语句部分程序就自动停止了。。。
请问各位大佬,以上两种情况都是什么问题呢?

        public void method12(){
                int year = 0, month = 0, day = 0;
                //下面这段代码实现客户输入年份,并对类型不匹配的异常进行捕捉说明。
                while(true){
                        System.out.println("请输入年份(>0):");                       
                        Scanner scan = new Scanner(System.in);
                        try {
                                year = scan.nextInt();
                        } catch (InputMismatchException e) {
                                System.out.println("您输入的是"+year);
                                System.out.println("输入的年份类型不匹配,请输入正整数");
                        }
                        if(year > 0){
                                break;
                        }else{
                                System.out.println("年份不能为负,请输入正数!");
                        }
                        scan.close();
                }
        }

巴巴鲁 发表于 2021-9-7 16:26:41

本帖最后由 巴巴鲁 于 2021-9-7 17:00 编辑

你把 year = scan.nextInt();放到try的外面,第一次异常的话,第二次在输入前try语句块就异常了(因为在你赋值前判定的,没有异常才会进入try)

dequantianhe 发表于 2021-9-7 20:11:14

巴巴鲁 发表于 2021-9-7 16:26
你把 year = scan.nextInt();放到try的外面,第一次异常的话,第二次在输入前try语句块就异常了(因为在你 ...

没太明白你的意思,不过我后来又试了试,只要把scan.close()注释掉就可以了,貌似问题是出在了Scanner的使用上,第一次的scan.close()影响了第二次循环的Scanner的使用,但具体怎么解释我就不懂了,对了是不是看看原码

巴巴鲁 发表于 2021-9-7 20:49:02

本帖最后由 巴巴鲁 于 2021-9-7 20:53 编辑

你看看我的代码,我注释那句你看看位置,自己体会一下,我可能没有表达清楚,反正你写的代码第一次year为3.4的话,第二次,第三次......都是3.4,year = scan.nextInt();不会执行
package com.my;

import java.util.InputMismatchException;
import java.util.Scanner;

public class Test
{
    public static void main(String[]args)
    {
      int year = 0, month = 0, day = 0;
      Scanner scan = new Scanner(System.in);
      while(true)
      {
            System.out.println("请输入年份(>0):");
            year = scan.nextInt(); // 这句代码在try外面,第一次如果输入小数,第二次就会产生异常,不会执行try语句块异常后的语句,所以会出现死循环
            try
            {
                System.out.println("try语句块结束了");
            }
            catch (InputMismatchException e)
            {
                System.out.println("您输入的是"+year);
                System.out.println("输入的年份类型不匹配,请输入正整数");
            }
            if(year > 0)
            {
                break;
            }
            else
            {
                System.out.println("年份不能为负,请输入正数!");
            }
      }
      scan.close();
    }
}

dequantianhe 发表于 2021-9-7 21:19:38

巴巴鲁 发表于 2021-9-7 20:49
你看看我的代码,我注释那句你看看位置,自己体会一下,我可能没有表达清楚,反正你写的代码第一次year为3. ...

额,不太理解,为啥要把year = scan.nextInt();放在try-catch结构的外面呢?
现在捕捉的就是year = scan.nextInt();赋值时可能出现的类型不匹配的异常呢。
如果放在外边,那么第一次如果输入3.4那就直接异常断出了,不能实现通过循环让客户再次输入正确的年份的目标啊。

巴巴鲁 发表于 2021-9-7 21:50:25

dequantianhe 发表于 2021-9-7 21:19
额,不太理解,为啥要把year = scan.nextInt();放在try-catch结构的外面呢?
现在捕捉的就是year = scan ...

不好意思,是我懵了,应该就是缓存的问题

dequantianhe 发表于 2021-9-8 09:15:51

巴巴鲁 发表于 2021-9-7 21:50
不好意思,是我懵了,应该就是缓存的问题

没关系,多谢你的提议~

不会起名字的我 发表于 2021-10-22 22:01:14

dequantianhe 发表于 2021-9-7 21:19
额,不太理解,为啥要把year = scan.nextInt();放在try-catch结构的外面呢?
现在捕捉的就是year = scan ...

复合语句内创建的对象仅在本复合语句中和本复合语句下的复合语句中使用
页: [1]
查看完整版本: try-catch语句可以用在while循环里嘛?