Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Герберт Шилдт. Java 2, v5.0 (Tiger). Новые возм...doc
Скачиваний:
5
Добавлен:
01.03.2025
Размер:
1.21 Mб
Скачать

Методы signum() u reverseBytes()

В числовые оболочки типов Integer и Long, добавлены методы signum() и reverseBytes (). Далее приведены синтаксические записи этих методов для типа Integer:

static int signum(int num)

static int reverseBytes(int num)

Метод signum() возвращает -1, если число num отрицательное, 0, если нулевое, и 1, если оно положительное. Метод reverseBytes () меняет на противоположный порядок байтов в числе пит и возвращает результат.

Далее приведены версии описанных методов для оболочки типа Long:

static int signum(long num)

static long reverseBytes(long num)

Поддержка 32-битных кодовых точек для символов Unicode

В версию Java 2 5.0 внесены значительные дополнения в типы character и String для поддержки 32-битных символов Unicode. В прошлом все символы Unicode могли храниться в шестнадцати битах, которые равны размеру значения типа char (и размеру значения, содержащегося в объекте типа character), поскольку эти значения лежали в диапазоне от 0 до FFFF. Но недавно набор символов Unicode был расширен и теперь требует больше 16 бит для хранения символа. Новая версия набора символов Unicode включает в себя символы, лежащие в диапазоне от 0 до 10FFFF.

Приведу три важных термина: кодовая точка или позиция (code point), кодовая единица или кодовое значение (code unit) и дополнительный символ (supplemental character), Применительно к языку Java кодовая точка — это код символа из диапазона от 0 до 10FFFF. В языке Java термин "кодовая единица" используется для ссылки на 16-битные символы. Символы, имеющие значения, большие, чем FFFF, называются дополнительными.

Расширение набора символов Unicode создало фундаментальные проблемы для языка Java, Поскольку у дополнительного символа значение больше, чем может вместить тип char, потребовались некоторые средства для хранения и обработки дополнительных символов. В версии Java 2 5.0 эта проблема решена двумя способами. Во-первых, язык Java использует два значения типа char для представления дополнительного символа. Первое из них называется верхним суррогатом (high surrogate), а второе — нижним суррогатом (low surrogate). Разработаны новые методы, такие как codePointAt(), для преобразований кодовых точек в дополнительные символы и обратно.

Во-вторых, в языке Java перегружены некоторые из существовавших ранее методов в классах Character и String. В перегруженных вариантах методов используются данные типа int вместо char. Поскольку размер переменной или константы типа int достаточно велик для размещения любого символа как единичного значения, этот тип может использоваться для хранения любого символа. Например, у метода isDigit() теперь два варианта, приведенные далее:

static boolean isDigit(char ch)

static boolean isDigit(int cp)

Новые подпакеты пакета java.Lang

В Java 2, v5.0 добавлены следующие подпакеты пакета java.lang:

  • java.lang.annotation

  • java.lang.instrument

  • java.lang.management

Далее дано краткое описание каждого из них:

java.lang.annotation

Новая функциональная возможность включения аннотаций в исходные тексты программ обеспечивается подпакетом java.lang.annotation. В нем определен интерфейс Annotation и перечислимые типы ElementType и Retention-Policy (аннотации подробно описаны в главе 7).

java.lang. instrument

В этом подпакете определены функциональные возможности для оснащения средствами контроля различных аспектов выполнения программ. Он содержит интерфейсы Instrumentation и ClassFileTransformer и класс ClaasDefinition.

java.lang.management

Пакет java.lang.management обеспечивает поддержку управления виртуальной машины Java (JVM) и среды выполнения программы. Пользуясь функциональными средствами этого подпакета, Вы можете наблюдать за различными аспектами выполнения программы и управлять ими.