Как использовать сканер, чтобы принимать только действительные значения int в качестве входных данных - PullRequest
22 голосов
/ 26 мая 2010

Я пытаюсь сделать небольшую программу более надежной, и мне нужна помощь с этим.

Scanner kb = new Scanner(System.in);
int num1;
int num2 = 0;

System.out.print("Enter number 1: ");
num1 = kb.nextInt();

while(num2 < num1) {
    System.out.print("Enter number 2: ");
    num2 = kb.nextInt();
}
  1. Число 2 должно быть больше, чем число 1

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

Ответы [ 6 ]

31 голосов
/ 26 мая 2010

Использование Scanner.hasNextInt():

Возвращает true, если следующий токен на входе этого сканера можно интерпретировать как значение int в основании по умолчанию с использованием метода nextInt(). Сканер не продвигается дальше любого ввода.

Вот фрагмент для иллюстрации:

Scanner sc = new Scanner(System.in);
System.out.print("Enter number 1: ");
while (!sc.hasNextInt()) sc.next();
int num1 = sc.nextInt();
int num2;
System.out.print("Enter number 2: ");
do {
    while (!sc.hasNextInt()) sc.next();
    num2 = sc.nextInt();
} while (num2 < num1);
System.out.println(num1 + " " + num2);

Вам не нужно parseInt или беспокоиться о NumberFormatException. Обратите внимание, что поскольку методы hasNextXXX не продвигаются дальше любого ввода, вам, возможно, придется вызвать next(), если вы хотите пропустить «мусор», как показано выше.

Смежные вопросы

4 голосов
/ 26 мая 2010
  1. условие num2
  2. не зная, что такое объект kb, я бы прочитал String, а затем try ing Integer.parseInt(), и если вы не catch исключение, то это число, если вы это сделаете, прочитайте новый, возможно, установив num2 в Integer.MIN_VALUE и используя логику того же типа в вашем примере.
3 голосов
/ 26 мая 2010

Это должно работать:

import java.util.Scanner;

public class Test {
    public static void main(String... args) throws Throwable {
        Scanner kb = new Scanner(System.in);

        int num1;
        System.out.print("Enter number 1: ");
        while (true)
            try {
                num1 = Integer.parseInt(kb.nextLine());
                break;
            } catch (NumberFormatException nfe) {
                System.out.print("Try again: ");
            }

        int num2;
        do {
            System.out.print("Enter number 2: ");
            while (true)
                try {
                    num2 = Integer.parseInt(kb.nextLine());
                    break;
                } catch (NumberFormatException nfe) {
                    System.out.print("Try again: ");
                }
        } while (num2 < num1);

    }
}
2 голосов
/ 26 мая 2010

Попробуйте это:

    public static void main(String[] args)
    {
        Pattern p = Pattern.compile("^\\d+$");
        Scanner kb = new Scanner(System.in);
        int num1;
        int num2 = 0;
        String temp;
        Matcher numberMatcher;
        System.out.print("Enter number 1: ");
        try
        {
            num1 = kb.nextInt();
        }

        catch (java.util.InputMismatchException e)
        {
            System.out.println("Invalid Input");
            //
            return;
        }
        while(num2<num1)
        {
            System.out.print("Enter number 2: ");
            temp = kb.next();
            numberMatcher = p.matcher(temp);
            if (numberMatcher.matches())
            {
                num2 = Integer.parseInt(temp);
            }

            else
            {
                System.out.println("Invalid Number");
            }
        }
    }

Вы также можете попытаться разобрать строку в int, но обычно люди стараются избегать исключения.

Что я сделал, так это то, что определил регулярное выражение, которое определяет число, \d означает числовую цифру. Знак + означает, что должна быть одна или несколько цифр. Дополнительная \ перед \d заключается в том, что в java \ является специальным символом, поэтому его необходимо экранировать.

0 голосов
/ 26 мая 2010

Что вы можете сделать, это также взять следующий токен в виде строки, преобразует эту строку в массив символов и проверить, что каждый символ в массиве является цифрой .

Я думаю, это правильно, если вы не хотите иметь дело с исключениями.

0 голосов
/ 26 мая 2010

Я вижу, что Character.isDigit идеально подходит для нужд, поскольку на входе будет только один символ. Конечно, у нас нет никакой информации об этом объекте kb, но на всякий случай это экземпляр java.util.Scanner, я бы также предложил использовать java.io.InputStreamReader для ввода в командной строке. Вот пример:

java.io.BufferedReader reader = new java.io.BufferedReader(new java.io.InputStreamReader(System.in));
try {
  reader.read();
}
catch(Exception e) {
  e.printStackTrace();
}
reader.close();
...