Цикл навсегда - PullRequest
       30

Цикл навсегда

0 голосов
/ 19 ноября 2009

Я пытаюсь зациклить исключение, но по какой-то причине оно не дает мне возможность переписать файл моего сканера:

Я не знаю, как использовать BufferedReader, поэтому я использую это. Любые подсказки?

Вот мой стандартный класс с моим методом

package arrayExceptionsWithInput;
import java.util.*;
public class GetThoseNumbersBaby {

    int firstInt;
    int secondInt;
    boolean error;
    Scanner yourNumbers = new Scanner(System.in);

    public void findNumbers()
    {
        System.out.println(" please enter your first number");
        firstInt = yourNumbers.nextInt();
        System.out.println(" pleas enter your second number");
        secondInt = yourNumbers.nextInt();
        int finalInt = (firstInt+secondInt);
        System.out.println("total is: " + finalInt);
    }
}

А вот мой основной класс с исключением, реализуемым с помощью цикла:

package arrayExceptionsWithInput;
import java.util.*;

public class InputException
{
    public static void main(String[] args)
    {
        boolean error = false;
        GetThoseNumbersBaby zack = new  GetThoseNumbersBaby();


        {
            do {
                try
                {
                    zack.findNumbers();
                }
                catch(InputMismatchException Q)
                {
                    System.out.println(" one of your integers was incorrect, please try again");
                    Q.printStackTrace();
                    error = true;
                } 
            } while (error == true);
        }
        error = false;
    }
}

Если у кого-то есть идеи о том, как это зациклить, я весь в ушах.

Ответы [ 3 ]

1 голос
/ 19 ноября 2009

Установить ошибку false до действия. Таким образом, вы получите правильное условие выхода, если пользователь правильно его выполнит.

error = false;
zack.findNumbers(); 
0 голосов
/ 19 ноября 2009

Вы выполняете цикл, пока 'error' переменная имеет значение 'true' . Однако оно становится 'true' только тогда, когда выброшено (то есть, когда выполняется блок 'catch' ). Поток управления не достигает этого.

0 голосов
/ 19 ноября 2009

я тоже решил избавиться от класса метода и просто поместите метод в область исключения try.

использовал .nextLine после сканера, и он кажется исправленным.

это выглядит нормально?

package arrayExceptionsWithInput;
import java.util.*;
public class InputException
{
public static void main(String[] args)
{
boolean error = false;
int firstInt;
int secondInt;
Scanner yourNumbers = new Scanner(System.in);
{
    do{
            try
            {

                    System.out.println(" please enter your first number");
                    firstInt = yourNumbers.nextInt();
                    yourNumbers.nextLine();
                    System.out.println(" pleas enter your second number");
                    secondInt = yourNumbers.nextInt();
                    yourNumbers.nextLine();
                    int finalInt = (firstInt+secondInt);
                    System.out.println("total is: " + finalInt);
                    yourNumbers.nextLine();

            }
            catch(InputMismatchException Q)
            {

                Q.printStackTrace();
                System.out.println(" one of your integers was incorrect, please try again");
                error = true;
                yourNumbers.nextLine();
            }   
        }while (error == true);
    }error = false;
}
}
...