Читаем Философия Java3 полностью

Различные компьютеры могут хранить данные с различным порядком следования байтов. Прямой порядок big_endian располагает старший байт по младшему адресу памяти, а для обратного порядка little_endian старший байт помещается по высшему адресу памяти. При хранении значения, занимающего более одного байта, такого как число int, float и т. п., вам, возможно, придется учитывать различные варианты следования байтов в памяти. Буфер ByteBuffer укладывает данные в порядке big_endian, такой же способ всегда используется для данных, пересылаемых по сети. Порядок следования байтов в буфере можно изменить методом order(), передав ему аргумент ByteOrder.BIG_ENDIAN или ByteOrder. LITTLE_ENDIAN.

Рассмотрим двоичное представление байтового буфера, содержащего следующие два байта:

0

0

0

0

0

0

0

97

byte


а

char

0

0

0

97

short

0

97

int

0.0

1.36Е-43

float

97

long

4.8Е-322

double

Если прочитать эти данные как тип short (ByteBuffer.asShortBuffer()), то получите число 97 (00000000 01100001), но при другом порядке следования байтов будет получено число 24 832 (01100001 00000000).

Следующий пример показывает, как порядок следования байтов отражается на символах в зависимости от настроек буфера:

//: io/Endians.java

// Endian differences and data storage, import java.nio.*, import java.util *;

import static net.mindview util.Print.*,

public class Endians {

public static void main(String[] args) {

ByteBuffer bb = ByteBuffer.wrap(new byte[12]); bb asCharBuffer().put("abcdef"), print(Arrays toString(bb arrayO)). bb rewindO,

bb.order(ByteOrder BIG_ENDIAN). bb.asCharBuffer().put("abcdef"). print(Arrays toString(bb arrayO)), bb. rewindO;

bb.order(ByteOrder LITTLE_ENDIAN); bb.asCharBuffer().put("abcdef"); pri nt(Arrays.toStri ng(bb.array()));

}

} /* Output.

[0, 97, 0. 98, 0, 99, 0, 100, 0, 101. 0. 102] [0. 97. 0, 98. 0. 99. 0, 100, 0. 101. 0. 102] [97, 0. 98. 0. 99. 0. 100, 0, 101. 0. 102, 0] *///:-

В буфере ByteBuffer достаточно места для хранения всех байтов символьного массива, поэтому для вывода байтов подходит метод аггау(). Метод аггау() является необязательным, и вызывать его следует только для буфера, созданного на базе существующего массива; в противном случае произойдет исключение UnsupportedOperationException.

Символьный массив помещается в буфер ByteBuffer посредством представления CharBuffer. При выводе содержащихся в буфере байтов мы видим, что настройка по умолчанию совпадает с режимом big_endian, в то время как атрибут little_endian переставляет байты в обратном порядке.

Буферы и операции с данными

Следующая диаграмма демонстрирует отношения между классами пакета nio; она поможет вам разобраться, как можно перемещать и преобразовывать данные. Например, если вы захотите записать в файл байтовый массив, то сначала вложите его в буфер методом ByteBuffer.wrap(), затем получите из потока File-OutputStream канал методом getChannel(), а потом запишите данные буфера ByteBuffer в полученный канал FileChannel.

Новый ввод/вывод (nio) 521 ^-Инструменты-^

Файловая система или сеть

Channels

FilelnputStream FileOutputStream RandomAccessFile

Socket DatagramSocket ServerSocket

getChannelO

write(ByteBuffer)

ByteBuffer

— FileChannel

read(ByteBuffer) map(FileChannel.MapMode,position,size)

ZZ3

Mapped ByteBuffer

В адресном пространстве процесса

array()/get(byteQ)

byte[]

wrap(byleQ) array()/get(charQ)

asCharBuffer()

char[ ]

CharBuffer

/vrap(charQ) rray()/get(doublen^

asDoubleBuffer()

double[ ]

DoubleBuffer

wrap(doubleQ) array()/get(floatQ)

asFloatBuffer()

float[ ]

FloatBuffer

wrap(floatQ) array()/get(intQ)

aslntBuffer()

int[]

InyBuffer

wrap(intQ) array()/get(longQ)

asLongBuffer()

LongBuffer

long[]

wrap(longQ) array()/get(shortp)^

asShortBuffer()

ShortBuffer

short[ ]

wrap(shortQ)

- Кодирование/декодирование ByteBuffer -

В кодированный поток байт encode(CharBuffer) ^_

Загрузка кодовых страниц Charset.forName(«8859_1»)

CharsetEncoder

Charse

CharsetDecoder

newEncoder() newDecoder

decode(ByteBuffer) if

В кодированный поток байт

Перейти на страницу:

Похожие книги

Access 2002: Самоучитель
Access 2002: Самоучитель

В книге рассматривается широкий круг вопросов, связанных с использованием программной среды Access 2002, которая является составной частью пакета Office 2002 и предназначена для создания банка данных в самых различных предметных областях.Подробно описывается методика проектирования объектов базы данных (таблицы, формы, отчеты, страницы доступа к данным, запросы, модули).Детально обсуждаются вопросы создания интегрированной базы данных в единой среде Access 2002: формирование БД с нуля, конвертирование в программную среду баз данных, созданных в ином программном окружении – Clarion, FoxPro.Особое внимание уделяется формированию разнообразных запросов к интегрированной базе данных Access 2002 с использованием языков программирования SQL, VBA и макросов.Приводятся общие сведения о возможностях языка обмена данными между различными компьютерами и приложениями (XML). Описываются возможности использования гиперссылок, связывающих базу данных с другими программными продуктами. Объясняется, как можно работать с базой данных Access 2002 без установки ее на компьютер, используя технологию ODBC (Open Data Base Connectivity). В приложениях приводятся количественные параметры Access 2002 и связанная с этой СУБД терминология.Предлагаемая книга будет полезна специалистам, занимающимся практической разработкой банков данных и приложений на их основе, а также студентам вузов, изучающим информатику.

Павел Юрьевич Дубнов

Программирование, программы, базы данных / ОС и Сети / Книги по IT