Философия Java3
Шрифт:
ByteBuffer bb = ByteBuffer allocate(BSIZE). // При выделении буфер заполняется нулями int i = 0;
while(i++ < bb limitO)
if(bb.get != 0)
print("nonzero");
printC'i = " + i); bb rewindO:
// Сохраняем и считываем символьный массив bb asCharBufferO put("Howdy!"); char c,
while((c = bb.getCharO) != 0) printnb(c + " ");
printO. bb rewindO:
// Сохраняем и считываем число типа short: bb.asShortBuffer.put((short >471142): print(bb.getShortO), bb. rewindO;
// Сохраняем
// Сохраняем и считываем число типа long-bb.asLongBufferO put(99471142): print(bb.getLongO); bb. rewindO,
// Сохраняем и считываем число типа float. bb.asFloatBufferO put(99471142): print(bb getFloatO); bb. rewindO.
// Сохраняем и считываем число типа 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 }), // Чтение и
// Назначение нового предела перед смещением буфера 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,