Java ByteBuffer Put vs wrap

Java中填充预先分配的ByteBuffer的最快方法是什么?

我首先使用“assignedirect”设置ByteBuffer的大小,这只需要完成一次.在我需要尽可能快地填充它(循环它)之后,新数据以每5ms的形式到达byte []数组,并且没有占用内存,因为我已经预先分配了ByteBuffer.
目前我使用“.put()”指令,在我的系统中需要大约100ms才能完成.
还有另一种填充ByteBuffer的方法吗? “.wrap()”函数运行得更快而不重新分配数组吗?

解决方法:

我希望你的意思是byte []而不是字节[]

put()是将byte []复制到ByteBuffer中的最快方法.更快的方法是首先写入ByteBuffer而不是使用byte [].

如果副本花费100毫秒,也许您正在复制太多数据.在此测试中,它以128微秒的速度复制1 MB.

ByteBuffer bb = ByteBuffer.allocateDirect(1024 * 1024);
byte[] bytes = new byte[bb.capacity()];

int runs = 50000;
long start = System.nanoTime();
for (int i = 0; i < runs; i++) {
    bb.clear();
    bb.put(bytes);
}
long time = System.nanoTime() - start;
System.out.printf("Average time to copy 1 MB was %.1f us%n", time / runs / 1e3);

版画

Average time to copy 1 MB was 128.9 us
上一篇:Java – 将16位带符号的pcm音频数据数组转换为双数组


下一篇:Java ByteBuffer发出有符号和无符号类型的问题,将字节数组转换为整数