This question already has an answer here:
Scanner scanner = new Scanner();
int number = 1;
do
{
try
{
option = scanner.nextInt();
}
catch (InputMismatchException exception)
{
System.out.println("Integers only, please.");
}
}
while (number != 0);
Despite the exception handling, this code will enter an infinite loop when non-integer input is given. Instead of Scanner
pausing to collect input in the next iteration, it simply continues throwing InputMismatchException
s until the program is killed.
What's the best way to scan for integer (or another type, I suppose) input, discarding invalid input and continuing the loop normally?
From the javadoc: This method will throw InputMismatchException if the next token cannot be translated into a valid int value as described below. If the translation is successful, the scanner advances past the input that matched.
Note the second sentence there, it only advances IF it is successful. This means that you will need to change your catch block to something like the following:
I think this is better
I was confused with the code sample, so I had to rewrite it. Hope this helps you even its been years. I know its different, but when I tried adding the numbers using the sample code I got confused along the way.
At first what was bugging me was it counts the error.
I would rather do away with the do-while loop, tried it before and if you miss something it goes on to an infinite loop.
change your code to this
You should check whether or not the input can be parsed as an int before attempting to assign the input's value to an int. You should not be using an exception to determine whether or not the input is correct it is bad practice and should be avoided.
This way you can check whether or not the input can be interpreted as an int and if so assign the value and if not display a message. Calling that method does not advance the scanner.
If it scans a non-int variable, exception will pop, if not flag will be true and loop will exit.