
- •Глава 2 3
- •Глава 3 11
- •Глава 10 117
- •Глава 2 Автоупаковка и автораспаковка
- •Обзор оболочек типов и упаковки значений
- •Основы автоупаковки/распаковки
- •Автоупаковка и методы
- •Автоупаковка/распаковка в выражениях
- •Автоупаковка/распаковка логических и символьных значений
- •Помощь автоупаковки/распаковки в предупреждении ошибок
- •Предостережения
- •Глава 3 Настраиваемые типы
- •Что такое настраиваемые типы
- •Простой пример применения настраиваемых типов
- •Средства настройки типов работают только с объектами
- •Различия настраиваемых типов, основанных на разных аргументах типа
- •Как настраиваемые типы улучшают типовую безопасность
- •Настраиваемый класс с двумя параметрами типа
- •Общий вид объявления настраиваемого класса
- •Ограниченные типы
- •Применение метасимвольных аргументов
- •Ограниченные метасимвольные аргументы
- •Создание настраиваемого метода
- •Настраиваемые конструкторы
- •Настраиваемые интерфейсы
- •Типы raw и разработанный ранее код
- •Иерархии настраиваемых классов
- •Использование настраиваемого суперкласса
- •Настраиваемый подкласс
- •Сравнения типов настраиваемой иерархии во время выполнения программы
- •Переопределенные методы в настраиваемом классе
- •Настраиваемые типы и коллекции
- •Стирание
- •Методы-подставки
- •Ошибки неоднозначности
- •Некоторые ограничения применения настраиваемых типов
- •Нельзя создавать объекты, используя параметры типа
- •Ограничения для статических членов класса
- •Ограничения для настраиваемого массива
- •Ограничение настраиваемых исключений
- •Заключительные замечания
- •Глава 4 Вариант For-Each цикла for
- •Описание цикла for-each
- •Обработка многомерных массивов в цикле
- •Область применения цикла for в стиле for-each
- •Использование цикла for в стиле for-each для обработки коллекций
- •Создание объектов, реализующих интерфейс Iterable
- •Глава 5 Аргументы переменной длины
- •Средство формирования списка с переменным числом аргументов
- •Перегрузка методов с аргументом переменной длины
- •Аргументы переменной длины и неоднозначность
- •Глава 6 Перечислимые типы
- •Описание перечислимого типа
- •Методы values() и valueOf()
- •Перечислимый тип в Java — это класс
- •Перечислимые типы, наследующие тип enum
- •Глава 7 Метаданные
- •Описание средства "метаданные"
- •Задание правил сохранения
- •Получение аннотаций во время выполнения программы с помощью рефлексии
- •Листинг 7.3. Получение всех аннотаций для класса и метода
- •Интерфейс AnnotatedElement
- •Использование значений по умолчанию
- •Аннотации-маркеры
- •Одночленные аннотации
- •Встроенные аннотации
- •Несколько ограничений
- •Глава 8 Статический импорт
- •Описание статического импорта
- •Общий вид оператора статического импорта
- •Импорт статических членов классов, созданных Вами
- •Неоднозначность
- •Предупреждение
- •Глава 9 Форматированный ввод/вывод
- •Форматирование вывода с помощью класса Formatter
- •Конструкторы класса Formatter
- •Методы класса Formatter
- •Основы форматирования
- •Форматирование строк и символов
- •Форматирование чисел
- •Форматирование времени и даты
- •Спецификаторы %n и %%
- •Задание минимальной ширины поля
- •Задание точности представления
- •Применение флагов форматирования
- •Выравнивание вывода
- •Флаг запятая
- •Применение верхнего регистра
- •Использование порядкового номера аргумента
- •Применение метода printf() языка Java
- •Класс Scanner
- •Конструкторы класса Scanner
- •Описание форматирования входных данных
- •Несколько примеров применения класса Scanner
- •Установка разделителей
- •Другие свойства класса Scanner
- •Глава 10 Изменения в api
- •Возможность применения настраиваемых типов при работе с коллекциями
- •Обновление класса Collections
- •Почему настраиваемые коллекции
- •Модернизация других классов и интерфейсов для применения настраиваемых типов
- •Новые классы и интерфейсы, добавленные в пакет java.Lang
- •Класс ProcessBulider
- •Класс StringBuilder
- •Интерфейс Appendable
- •Интерфейс Iterable
- •Интерфейс Readable
- •Новые методы побитной обработки классов Integer и Long
- •Методы signum() u reverseBytes()
- •Поддержка 32-битных кодовых точек для символов Unicode
- •Новые подпакеты пакета java.Lang
- •Классы Formatter и Scanner
Описание форматирования входных данных
Создав объект типа Scanner, очень просто использовать его для чтения форматированных входных данных. Как правило, объект класса Scanner читает лексемы (tokens) из базового источника, который Вы задали при создании объекта типа Scanner. Применительно к классу Scanner, лексема — это порция вводимых данных, обособленная набором разделителей, по умолчанию пробелами. При считывании лексема сопоставляется с конкретным регулярным выражением (regular expression), задающим формат ввода. Хотя класс scanner разрешает определять собственный тип выражения, соответствие которому будет проверяться в последующих операциях ввода, в нем содержится много предопределенных образцов, соответствующих базовым типам, таким как int и double, и строкам. Следовательно, зачастую Вам не придется формировать образец для проверки соответствия вводимых данных.
Обычно для использования класса scanner необходимо выполнить следующие шаги.
1. С помощью одного из методов hasNextX класса Scanner определить, доступна ли для ввода порция данных типа х.
Если да, считать ее с помощью одного из методов nextX класса scanner.
Повторять процесс, пока не исчерпан поток ввода.
Как показывает описанный процесс ввода, в классе scanner определены два набора методов, позволяющих читать входные данные. Первый содержит методы hasNextX, перечисленные в табл. 9.7. Эти методы определяют, доступны ли для ввода данные заданного типа. Например, вызов метода hasNextint() возвращает true, только если следующая лексема, предназначенная для считывания, — целое число. Если данные указанного типа доступны, они считываются с помощью одного из методов nextX Класса Scanner, перечисленных в табл. 9.8, Например, для считывания очередного целого числа вызовите метод NextInt(). В приведенном далее фрагменте показано, как прочесть последовательность целых значений с клавиатуры:
Scanner conin = new Scanner(System.in);
int i;
// Считывает последовательность целых чисел
whilefconin.hasMextlnt()) {
i = conin.nextlnt();
}
Таблица 9.7. Методы hasNext класса Scanner
Метод |
Описание |
boolean hasNext() |
Возвращает true, если доступна для чтения лексема какого-либо типа. Возвращает false в противном случае |
boolean hasNext(Pattern pattern) |
Возвращает true, если лексема, соответствующая образцу, переданному в параметре pattern, доступна для чтения. Возвращает false в противном случае
|
boolean hasNext(String pattern) |
Возвращает true, если лексема, соответствующая образцу, переданному в параметре pattern, доступна для чтения. Возвращает false в противном случае |
boolean hasNextBigDecimal() |
Возвращает true, если значение, которое можно сохранить в объекте типа Big-Decimal, доступно для считывания, Возвращает false в противном случае |
boolean hasNextBiglnteger() |
Возвращает true, если значение, которое можно сохранить в объекте типа Biglnteger, доступно для считывания. Возвращает false в противном случае. Использует основание системы счисления, принятое по умолчанию (равно 10, если не менялось) |
boolean hasNextBiglnteger (int radix) |
Возвращает true, если значение, которое можно сохранить в объекте типа Biglnteger, доступно для считывания. Возвращает false в противном случае |
boolean hasNextBoolean() |
Возвращает true, если значение типа boolean доступно для считывания. Возвращает false в противном случае |
boolean hasNextByte () |
Возвращает true, если значение типа byte доступно для считывания, Возвращает false в противном случае. Использует основание системы счисления, принятое по умолчанию (равно 10, если не менялось)
|
boolean hasNextByte(int radix) |
Возвращает true, если значение типа byte доступно для считывания. Возвращает false в противном случае |
boolean hasNextDouble() |
Возвращает true, если значение типа double доступно для считывания. Возвращает false в противном случае |
boolean hasNextFloat() |
Возвращает true, если значение типа float доступно для считывания. Возвращает false в противном случае |
boolean hasNextlnt() |
Возвращает true, если значение типа int доступно для считывания. Возвращает false в противном случае. Использует основание системы счисления, принятое по умолчанию (равно 10, если не менялось) |
boolean hasNextlnt(int radix) |
Возвращает true, если значение типа int доступно для считывания. Возвращает false в противном случае |
boolean hasNextLong() |
Возвращает true, если значение типа long доступно для считывания. Возвращает false в противном случае. Использует основание системы счисления, принятое по умолчанию (равно 10, если не менялось) |
boolean hasNextLong(int radix) |
Возвращает true, если значение типа long доступно для считывания. Возвращает false в противном случае |
boolean hasNextShort() |
Возвращает true, если значение типа short доступно для считывания. Возвращает false в противном случае. Использует основание системы счисления, принятое по умолчанию (равно 10, если не менялось) |
boolean hasNextShort(int radix) |
Возвращает true, если значение типа short доступно для считывания. Возвращает false в противном случае |
Цикл while прекращается, как только очередная лексема — нецелочисленная. Следовательно, цикл прерывает чтение целых чисел, как только обнаруживает нецелое число в потоке ввода.
Если метод next не может найти данные того типа, которой он ищет, он генерирует исключение типа NoSuchElementException. Следовательно, лучше убедиться в том, что данные искомого типа доступны для считывания с помощью метода hasNext прежде, чем вызывать соответствующий метод next.