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

// Сохраняем и считываем число типа double: bb asDoubleBufferO put(99471142): print(bb getDoubleO). bb. rewindO;

}

} /* Output-i = 1025 Howdy ! 12390 99471142 99471142 9 9471144E7

9.9471142E7 *///.-

После выделения байтового буфера мы убеждаемся в том, что его содержимое действительно заполнено нулями. Проверяются все 1024 значения, хранимые в буфере (вплоть до последнего, индекс которого (размер буфера) возвращается методом limit()), и все они оказываются нулями.

Простейший способ вставить примитив в ByteBuffer основан на получении подходящего «представления» этого буфера методами asCharBuffer(), asShort-Buffer() и т. п., и последующем занесении в это представление значения методом put(). В примере мы так поступаем для каждого из простейших типов. Единственным исключением из этого ряда является использование буфера ShortBuffer, требующего приведения типов (которое усекает и изменяет результирующее значение). Все остальные представления не нуждаются в преобразовании типов.

Представления буферов

«Представления буферов» дают вам возможность взглянуть на соответствующий байтовый буфер «через призму» некоторого примитивного типа. Байтовый буфер все так же хранит действительные данные и одновременно поддерживает представление, поэтому все изменения, которые вы сделаете в представлении, отразятся на содержимом байтового буфера. Как было показано в предыдущем' примере, это удобно для вставки значений примитивов в байтовый буфер. Представления также позволяют читать значения примитивов из буфера, по одному (раз он «байтовый» буфер) или пакетами (в массивы). Следующий пример манипулирует целыми числами (int) в буфере ByteBuffer с помощью класса IntBuffer:

//• io/IntBufferDemo java // Работа с целыми числами в буфере ByteBuffer // посредством буфера IntBuffer import java nio *,

public class IntBufferDemo {

private static final int BSIZE = 1024, public static void main(String[] args) {

ByteBuffer bb = ByteBuffer.allocate(BSIZE); IntBuffer ib = bb.asIntBufferO; // Сохранение массива int:

ib put(new int[]{ 11, 42, 47, 99, 143, 811. 1016 }), // Чтение и запись по абсолютным позициям: System out.println(ib.get(3)), ib put(3, 1811):

// Назначение нового предела перед смещением буфера ib flipO.

whi 1 е(ib hasRemainingO) { int i = ib.getO; System.out.printin(i),

}

}

} /* Output 99 11 42 47

143 811 1016 *///:-

Перегруженный метод put() первый раз вызывается для помещения в буфер массива целых чисел int. Последующие вызовы put() и get() обращаются к конкретному числу int из байтового буфера ByteBuffer. Заметьте, что такие обращения к простейшим типам по абсолютной позиции также можно осуществить напрямую через буфер ByteBuffer.

Как только байтовый буфер ByteBuffer будет заполнен целыми числами или другими примитивами через представление, его можно передать для непосредственной записи в канал. Настолько же просто считать данные из канала и использовать представление для преобразования данных к конкретному простейшему типу. Вот пример, который трактует одну и ту же последовательность байтов как числа short, int, float, long и double, создавая для одного байтового буфера ByteBuffer различные представления:

//: io/ViewBuffers.java import java.nio.*;

import static net.mindview.util.Print.*;

public class ViewBuffers {

public static void main(String[] args) { ByteBuffer bb = ByteBuffer.wrap(

new byte[]{ 0. 0. 0. 0. 0. 0. 0. 'a' }); bb.rewind(); printnb("Буфер Byte "); while(bb.hasRemainingO)

printnb(bb.position()+ " -> " + bb.getO + \ ");

printO; CharBuffer cb -

((ByteBuffer)bb.rewind()).asCharBuffer(); printnb("Буфер Char "); while(cb.hasRemainingO)

printnb(cb.position() + " -> " + cb.getO + \ ");

printO;

FloatBuffer fb -

((ByteBuffer)bb.rewi nd()).asFloatBuffer(); printnb("Буфер Float "); while(fb.hasRemainingO)

printnb(fb.position()+ " -> " + fb.getO + ");

printO; IntBuffer ib -

((ByteBuffer)bb.rewind()).asIntBuffer(); printnb("Буфер Int "); while(ib.hasRemainingO)

printnb(ib.position()+ " -> " + ib.getO + ". ");

printO; LongBuffer lb =

((ByteBuffer)bb.rewind()).asLongBuffer(); printnbCБуфер Long "); while(lb.hasRemainingO)

printnb(1b.position()+ " -> " + Ib.getO + ". ");

printO;

ShortBuffer sb =

((ByteBuffer)bb.rewind()).asShortBuffer(), pri ntnbCБуфер Short "), while(sb hasRemainingO)

printnb(sb position()+ " -> " + sb.getO + ");

printO,

DoubleBuffer db =

((ByteBuffer)bb.rewi nd()) asDoubleBuffer(): printnb("Буфер Double "), while(db hasRemainingO)

printnb(db position()+ " -> " + db getO + ", ");

}

} /* Output

Буфер Byte 0 -> 0. 1 -> 0, 2 -> 0. 3 -> 0. 4 -> 0, 5 -> 0. 6 -> 0. 7 -> 97,

Буфер Char 0 -> . 1 -> , 2 -> , 3 -> a,

Буфер Float 0 -> 0 0. 1 -> 1.36E-43,

Буфер Int 0 -> 0. 1 -> 97,

Буфер Long 0 -> 97,

Буфер Short 0 -> 0, 1 -> 0. 2 -> 0, 3 -> 97.

Буфер Double 0 -> 4 8E-322. *///.-

Байтовый буфер ByteBuffer создается как «обертка» для массива из восьми байтов, который затем и просматривается с помощью представлений для различных простейших типов.

О «порядке байтов

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

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

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