Читаем Философия 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 создается как «обертка» для массива из восьми байтов, который затем и просматривается с помощью представлений для различных простейших типов.

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

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

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

1С: Бухгалтерия 8 с нуля
1С: Бухгалтерия 8 с нуля

Книга содержит полное описание приемов и методов работы с программой 1С:Бухгалтерия 8. Рассматривается автоматизация всех основных участков бухгалтерии: учет наличных и безналичных денежных средств, основных средств и НМА, прихода и расхода товарно-материальных ценностей, зарплаты, производства. Описано, как вводить исходные данные, заполнять справочники и каталоги, работать с первичными документами, проводить их по учету, формировать разнообразные отчеты, выводить данные на печать, настраивать программу и использовать ее сервисные функции. Каждый урок содержит подробное описание рассматриваемой темы с детальным разбором и иллюстрированием всех этапов.Для широкого круга пользователей.

Алексей Анатольевич Гладкий

Программирование, программы, базы данных / Программное обеспечение / Бухучет и аудит / Финансы и бизнес / Книги по IT / Словари и Энциклопедии
1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

Финансы / Программирование, программы, базы данных