- •Глава 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
Неоднозначность
Используя средство статического импорта, нужно быть очень внимательным, чтобы не создать неоднозначных ситуаций. Если у двух классов или интерфейсов используется одно и то же имя для статического члена, и оба эти класса или интерфейса импортируются в один и тот же блок компиляции, компилятор не знает какое из этих имен выбрать, если они применяются без уточнения с помощью имени класса. Например, предположим, что в пакет MyMsg из листинга 8.4 включен приведенный в листинге 8.5 класс, в котором также объявлено статическое поле, названное upper.
Листинг 8.5. Неоднозначность, возникающая при статическом импорте
package MyMsg;
public class X {
public static final int UPPER = 11;
// ...
}
Если статические члены класса из листинга 8.5 импортируются в программу, которая также импортирует статические члены класса Msg, возникнет неоднозначность, как только обнаружится идентификатор upper. Например, в приведенных далее операторах статического импорта:
import static MyMsg.Msg.*;
import static MyMsg.X.*;
неуточненное имя UPPER ссылается на поле Msg.UPPER или на поле X.UPPER?
Предупреждение
Несмотря на удобство, предоставляемое статическим импортом, важно не злоупотреблять этим программным средством. Помните, что в языке Java библиотеки собраны в пакеты для того, чтобы избежать конфликтов пространств имен. Когда Вы импортируете статические члены, Вы переносите их в глобальное пространство имен (global namespace). Следовательно, увеличиваете вероятность возникновения конфликтов в пространстве имен, неоднозначности и непреднамеренного сокрытия других имен. Если Вы используете статический член в программе один или два раза, нет смысла импортировать его. Кроме того, некоторые статические имена, такие как system.out, настолько легко узнаваемы, что у Вас не появится желания импортировать их. Статический импорт желателен в тех случаях, когда статический член используется многократно, например, выполняя последовательности математических вычислений. Итак, Вам следует применять это средство программирования, но не злоупотреблять им.
Глава 9 Форматированный ввод/вывод
В версию Java 2 5.0 добавлена функциональная возможность форматирования вывода, которую долго ждали программисты. Несмотря на то, что язык Java всегда предлагал богатый и разнообразный API, в нем до сих пор не было легкого способа создания форматированного текстового вывода, особенно для числовых значений. В более ранних версиях Java, снабженных такими классами, как NumberFormat, DateFormat и MessageFormat, обеспечивались полезные функциональные возможности для форматирования вывода, но они были не слишком удобны. Более того, в отличие от языков С и C++, которые поддерживают легко осваиваемое и широко используемое семейство функций printf(), которое предлагает простой способ форматирования вывода, язык Java прежде не содержал таких методов. Причина заключалась в том, что форматирование в printf-стиле требует применения аргументов переменной длины (varargs), которые не поддерживались в языке Java до выхода Java 2 версии 5.0. Теперь, когда аргументы переменной длины включены в язык, добавить средства форматирования общего назначения стало просто.
В версию Java 2 5.0 включена поддержка чтения форматированных входных данных. Несмотря на то, что форматирование ввода всегда было возможно, оно требовало усилий больших, чем хотелось бы подавляющей части программистов. Теперь можно легко читать все типы числовых данных, строки и другие типы данных, независимо от того приходят ли они с диска, клавиатуры или из другого источника.
