概述
PoolingByteArrayOutputStream继承了ByteArrayOutputStream然后其中有加了一个ByteArrayPool,当ByteArrayOutputStream中的buff数组容量慢了之后,从ByteArrayPool获取新的数组,这样heap和垃圾回收机制可以少干活。这个重写了write()函数在调用基类的write之前先检查是否满了如果满了就用PoolingByteArrayOutputStream中的byte数组替换,并且把替换后的数组放回到pool中去。所以原来ByteArrayOutputStream中的数组扩容的逻辑没用被执行,因为每一次检测数组容量都是够的。
ByteArrayOutputStream
这个就是往一个数组里写byte如果小了就申请个新的数组,显示申请两倍的容量如果还是小了,就讲数组设为要求的容量。
public synchronized void write(byte[] buffer, int offset, int len) {
expand(len);
super.write(buffer, offset, len);
}
write函数是线程安全的。
ByteArrayOutputStream和他的基类的扩容机制有点不同
byte[] newbuf = mPool.getBuf((count + i) * 2);
基类
int newCapacity = oldCapacity << 1;