Logo    
Продукты, технологии Проекты, внедрения Новости мира IT Форумы Курилка Новые публикации Учебный центр
CitForum    CITForum на CD Море(!) аналитической информации! :: CITFORUM.RU
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware HOWTO

07.11.2004

[an error occurred while processing this directive]
Google
WWW CITForum.ru

2004 г.

Особенности реализации типа byte в Java Sun’s J2SDK

Вячеслав Яковенко, Издательский Дом "КОМИЗДАТ"

Написать эту статью меня побудило собственное блуждание среди трех сосен. И, промучавшись пару вечеров с тривиальной ситуацией, я понял, что она недокументированна и требует разъяснений.

Стандарты определяют byte, как встроенный тип позволяющий представлять числа от –128 до 127 [1, 103]. Кроме этого определено, что в Java все числовые типы являются знаковыми и модификатор unsigned не поддерживается. Известно так же, что Java не любит работать с типами ниже int и в большинстве случаев перед выполнением операций автоматически дополняет значения типа byte, char, short до типа int [2, 17].

Зная все выше сказанное, я редко пользуюсь типами ниже int по собственной инициативе – зачем лишний раз заставлять и без того не быструю виртуальную машину выполнять дополнительные преобразования. Однако в тех ситуациях когда, какая-либо функция возвращает byte или byte[] Вам придется работать с этими типами и учитывать их особенности.

Для начала рассмотрим пример, не вызывающий ошибок компиляции:

public class Class1{ 
public static void main (String[] args) { 
 
byte b = 26; 
 
} 
} 

В этом примере переменной b присваивается десятичное значение 26, которое не выходит за пределы диапазона типа byte. Проверив, содержимое переменной b отладчиком увидим в шестнадцатеричном виде: b = 0x1A, что соответствует 26 десятичным. Теперь рассмотрим шестнадцатеричное число - 0xC4, которое для без знаковых переменных соответствовало бы десятичному 196, а в Java соответствует –60 для byte с учетом знака. Проведем следующий эксперимент для числа –60:

 
public class Class1{ 
public static void main (String[] args) { 
 
byte b = -60; 
 
} 
} 

Этот вариант класса Class1 тоже компилируется без ошибок, но давайте посмотрим, что находится в переменной b с помощью отладчика - как и ожидалось она содержит «С4», но в несколько ином виде, чем в предыдущем варианте, а именно – «0xFFFFFFC4». Таким образом, компилятор выполнил пресловутое дополнение до int автоматически. Причем, что особенно интересно, так это то, что в случае если метод возвращает byte[] положительные числа в этом массиве будут типа byte, а отрицательные типа int. В моем случае это был метод public byte[] MessageDigest.digest() и соответствующий массив имел приблизительно такой вид: {0xffffffc4, 0xffffffc9, 0x33, 0x4b, 0xffffffac, …}.

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

public class Class1{ 
public static void main (String[] args) { 
 
byte b = 0xC4; 
 
} 
}

Данный пример идентичен предыдущему, за исключением формата представления числа –60. И он то, как раз вызывает ошибку компиляции. Поток ошибок в Linux приведен ниже:

Class1.java:5: possible loss of precision
found : int
required: byte
byte b = 0xc4;
^
1 error

В VJ++ эта программа приводит к ошибке Compiler Error J0068 Cannot implicitly convert 'int’ to 'byte'. Для того, чтобы заставить Java «проглотить» исходный код необходимо выполнить явное преобразование типа как показано ниже:

public class Class1{ 
public static void main (String[] args) { 
 
byte b = (byte)0xC4; 
 
} 
} 

Приведенная программа выглядит парадоксально, так как с первого взгляда подобное преобразование бессмысленно, однако учитывая все вышесказанное, оно просто необходимо. Более того, если Вам придется преобразовывать 16-ричное представление byte в строку, Вы столкнетесь с тем, что длина строки равна 2 для положительных byte, и 8 для отрицательных, приведенных к int.

Подводя итог статье, хочется отметить, что проще всего пользоваться типами, начинающимися с int и выше. Но при обработке массивов с младшими типами необходимо помнить о метаморфозах автоматического приведения типов.

Используемая литература

Чен М. С. Грифис С. В. Изи Э. Ф. «Программирование на JAVA: 1001 совет», Мн.: ООО «Попурри», 1997.

Стефен Р. Дэвис «Программирование на Microsoft Visual Java++», М.: издательский отдел «Русская Редакция» TOO “Channel Trading, Ltd.”, 1997.

Подписка на новости библиотеки:

Ближайшие курсы ЦИТ:

1-4 ноября 2004, Москва
Современные технологии анализа и проектирования информационных систем

1-5 ноября 2004, Москва
Основы передачи данных

9-10 ноября 2004, Москва
Основы моделирования бизнес-процессов и спецификации требований к ПО

Новые поступления в on-line библиотеку:

26 октября

  • Руководство FreeBSD (FreeBSD Handbook)
  • Спокойная революция
  • TV-тюнинг для компьютера
  • Новое поколение DVD
  • С видеокассеты на DVD

    21 октября

  • Обзор технических решений построения городской операторской сети на базе технологии "Optical Ethernet"
  • Алгоритм Rsync
  • Заметки о Linux-консоли
  • База данных без BDE

    19 октября

  • Функциональная безопасность программных средств
  • Технологические процессы и стандарты обеспечения функциональной безопасности в жизненном цикле программных средств
  • Так как же восстановить данные таблицы?
  • Использование CAST и табличных функций в PL/SQL

    14 октября

  • Разрезая биллионы
  • Платформа, которой не существует
  • Intel 9xx: время тестов
  • Сбалансированная система показателей: краткий обзор рынка программного обеспечения
  • Кросс-браузерность: теория и практика

    12 октября

  • В борьбе за каждый миллиметр
  • Хранилища данных и семантические разрывы
  • BI и ССП: связь между ними
  • Десять заповедей резервного копирования

    7 октября

  • XML-СУБД Sedna: технические особенности и варианты использования
  • Хранилище данных: вопросы и ответы
  • Порядок разработки ETL-процессов

    5 октября

  • Использование сокетов в Delphi
    Часть первая: стандартные сокеты
    Часть вторая: сокеты Windows
  • Задачи и аналитическая платформа для ВРМ
  • Методики, технологии и инструменты ВРМ
  • Выбор системы управления эффективностью бизнеса: решающие факторы

    30 сентября

  • MySQL: Руководство разработчика
  • MySQL: Руководство по ODBC и MyODBC

    28 сентября

  • СУБД ЛИНТЕР. Технический обзор
  • Новое в СУБД ЛИНТЕР 6.1
  • Использование ЛИНТЕР в качестве встроенной СУБД

    21 сентября

  • Материалы книги П.Б.Храмцова "Система доменных имен"
  • Храните свои терабайты в ящике
  • Тестирование контроллеров iSCSI
  • Девять ошибок, которые могут помешать работе SAN

    16 сентября

  • Курс лекций В.В.Воеводина "Параллельная обработка данных"
  • Заморочки от Oracle, или знать бы, где упасть
  • Реинжиниринг: многое в малом
  • CASE-технологии: что, когда, как?

    14 сентября

  • Сильнее угроза - крепче защита (обзор 16 инструментов)
  • GnuPG - OpenSource шифрование и цифровые подписи
  • Оптимизация не-HTML-сайтов для поисковых серверов
  • Новые графические супер-карты от ATI и NVidia
  • Новая жизнь Ethernet

    Все новости >>>



  • IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware HOWTO

    Реклама на IT-портале citforum.ru

    Нестандартные PR-акции - pr@citforum.ru
    Пресс-релизы и информация в каталог компаний - manager@citforum.ru
    Послать комментарий
    Информация для авторов
    Rambler's Top100 TopList This Web server launched on February 24, 1997
    Copyright © 1997-2000 CIT, © 2001-2004 CIT Forum
    Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав.