- •Глава 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 находит начало и конец лексемы, основываясь на наборе разделителей (delimiters). По умолчанию в качестве разделителей применяются пробелы, и именно они использовались в предыдущих примерах. Однако можно изменить разделители, вызвав метод useDelimiter(), формы синтаксической записи которого приведены в следующих строках:
Scanner useDelimiter(String pattern)
Scanner useDelimiter(Pattern pattern)
В этой записи параметр pattern — это регулярное выражение, определяющее набор разделителей.
В листинге 9.15 приведена новая версия программы из предыдущих листингов, которая считывает последовательность чисел, разделенных запятыми и любым количеством пробелов.
Листинг 9.15. Применение класса scanner для вычисления среднего
арифметического последовательности значений, разделенных запятыми
import java.util.*;
import java.io.*;
class SetDelimiters {
public static void main(String args[])
throws IOException {
int count = 0;
double sum = 0.0;
// Write output to a file.
FileWriter fout = new FileWriter("test.txt");
// Now, store values in comma-separated list.
fout.write("2, 3.4, 5,6, 7.4, 9.1, 10.5, done");
fout.close();
FileReader fin = new FileReader("Test.txt");
Scanner src = new Scanner(fin);
// Set delimiters to space and comma.
src.useDelimiter(", *");
// Read and sum numbers.
while(src.hasNext()) {
if(src.hasNextDouble()) {
sum += src.nextDouble();
count++;
}
else {
String str = src.next();
if(str.equals("done")) break;
else {
System.out.println("File format error.");
return;
}
}
}
fin.close();
System.out.println("Average is " + sum / count);
}
}
В листинге 9.15 числа, записанные в файл test.txt, разделены запятыми и пробелами. Использование образца для разделителей ", * " сообщает объекту класса Scanner о том, что запятую и 0 или более пробелов следует интерпретировать как разделитель. Вывод у версии программы из листинга 9.15 такой же, как и в предыдущих примерах.
Вы можете получить текущий образец разделителя, вызвав метод delimiter(), синтаксическая запись которого приведена в следующей строке:
Pattern delimiter()
Другие свойства класса Scanner
В классе Scanner определены и другие методы в дополнение к уже рассмотренным. Один из них, очень полезный в некоторых ситуациях, — findInLine(). Два варианта его синтаксической записи приведены в следующих строках:
String findInLine(Pattern pattern)
String findInLine(String pattern)
Этот метол ищет заданный образец в очередной строке текста. Если образец найден, соответствующая ему лексема извлекается из строки ввода и возвращается. В противном случае возвращается null. Этот метод действует независимо от установленного набора разделителей, Он полезен, когда нужно определить местоположение конкретного образца (подстроки в строке). В листинге 9.16 определяется местоположение поля Age во входной строке и затем выводится возраст.
Листинг 9.16. Демонстрация применения метода findInLine()
import java.util.*;
class FindInLineDemo {
public static void main(String args[]) {
String instr = "Name: Tom Age: 28 ID: 77";
Scanner conin = new Scanner(instr);
// Find and display age.
conin.findInLine("Age:"); // find Age
if(conin.hasNext())
System.out.println(conin.next());
else
System.out.println("Error!");
}
}
Вывод программы из листинга 9.16 — 28. Метод findInLine() применяется в программе для поиска подстроки "Age". После того как заданная подстрока найдена, считывается следующая за ней лексема, а она представляет возраст.
Варианты синтаксической записи родственного методу findInLine() метода findWithinHorizon() приведены в следующих строках:
String findWithinHorizon(Pattern pattern, int count)
String findWithinHorizon(String pattern, int count)
Этот метод пытается найти заданный образец в ближайших count символах. Если поиск удачен, метод возвращает найденный образец, в противном случае он возвращает null. Если количество символов count равно 0, поиск ведется во всей строке ввода пока не найдена подстрока, соответствующая образцу, или не обнаружен конец строки ввода.
Вы можете пропустить или обойти образец с помощью метода skip(), варианты синтаксической записи которого приведены в следующих строках:
Scanner skip(Pattern pattern)
Scanner skip(String pattern)
Если в строке ввода найдена подстрока, соответствующая образцу pattern, метод skip() просто перемещается за нее в строке ввода и возвращает ссылку на вызывающий объект. Если подстрока не найдена, метод skip () генерирует исключение типа NoSuchElementException.
Кроме того, в класс Scanner включены методы: radix(), возвращающий текущее основание системы счисления, используемое классом Scanner, useRadix(), устанавливающий основание системы счисления, и метод close(), закрывающий объект класса scanner.
