I am trying to have a scanner take input in a loop. Once the user wants to finish he can exit this loop. I have tried many different ways to do it but there is always some problem. This is the code:
private void inputEntries() {
Scanner sc = new Scanner(System.in);
System.out.println("Continue?[Y/N]");
while (sc.hasNext() && (sc.nextLine().equalsIgnoreCase("y"))) {//change here
System.out.println("Enter first name");
String name = sc.nextLine();
System.out.println("Enter surname");
String surname = sc.nextLine();
System.out.println("Enter number");
int number = sc.nextInt();
Student student = new Student(name, surname, number);
students.add(student);
try {
addToFile(student);
} catch (Exception ex) {
Logger.getLogger(TextReader.class.getName()).log(Level.SEVERE, null, ex);
}
System.out.println("Continue?[Y/N]");
}
}
The problem with the code above, which also happens on different methods I tried, is that when the user types Y, the Scanner will skip the first input for first name,and jump to the surname. If the user types N the loop stops correctly. Someone can explain the reason this happens, and how to overcome using Scanner class?
p.s: Doing something like while(sc.nextLine().equals("Y")), will cause the loop to terminate before getting input from user after first run of the loop.
This is because you are using
Scanner#nextmethod. And if you look at the documentation of that method, it returns the next token read.So, when you read user input using
nextmethod, it does not read thenewlineat the end. Which is then read by thenextLine()inside thewhileloop. And thus, yourfirstNamecontains anewlinewithout you knowing.So, you should use
nextLine()in your while rather thannext().Similar is the case with
nextIntmethod. It also does not read the newline. So, you canreadusingreadLineand convert it tointusingInteger.parseInt. It can throwNumberFormatExceptionif input value cannot be converted toint. So you need to handle it accordingly.You can try the below code: –
But, note one thing, if you enter a value that cannot be passed to
Integer.parseIntyou will get an exception, and that input will be skipped. For that case, you need to handle it by usingwhileloop.Or, if you don’t want to do that exception handling: –
You can add an
empty sc.nextLine()aftersc.nextInt(), that will consume thenewlineleft over, like this: –