彻底转变流,第2部分:优化Java内部I/O - 编程入门网
buffer = tmp;
// the new buffer is not shared
shared = false;
}
// copy in the subarray
System.arraycopy (data, offset, buffer, index, length);
index += length;
}
}
public void close () {
closed = true;
}
彻底转变流,第2部分:优化Java内部I/O(3)时间:2011-06-21 Merlin Hughes清单 3 中的字节数组抽取方法返回内部字节数组的副本。因为我们无法防止 调用程序把数据写到结果数组,所以我们无法安全地返回对内部缓冲区的直接引 用。 清单 3. 转换成字节数组
当方法提供对存储的数据的只读访问的时候,它们可以安全地高效地直接使 用内部字节数组。清单 4 显示了两个这样的方法。 writeTo() 方法把这个流的 内容写到输出流;它直接从内部缓冲区进行写操作。 toInputStream() 方法返 回了可被高效地读取数据的输入流。它所返回的 BytesInputStream (这是 ByteArrayInputStream 的非同步替代品。)能直接从我们的内部字节数组读取 数据。在这个方法中,我们还设置了标志,以表示内部缓冲区正被输入流共享。 这一点很重要,因为这样做可以防止在内部缓冲区正被共享时这个流被修改。 清单 4. 只读访问方法
可能会覆盖共享数据的唯一的一个方法是显示在清单 5 中的 reset() 方法 ,该方法清空了这个流。所以,如果 shared 等于 true 且 reset() 被调用, 那么我们创建新的内部缓冲区,而不是重新设置写索引。 清单 5. 重新设置流
彻底转变流,第2部分:优化Java内部I/O(4)时间:2011-06-21 Merlin Hughes更好的字节数组输入流 用 ByteArrayInputStream 类来提供对内存中的二进制数据基于流的读访问 是很理想的。但是,有时候,它的两个设计特点使我觉得需要一个替代它的类。 第一,这个类是同步的;我已讲过,对于多数应用程序来说没有这个必要。第二 ,如果在执行 mark() 前调用它所实现的 reset() 方法,那么 reset() 将忽略 初始读偏移。这两点都不是缺陷;但是,它们不一定总是人们所期望的。 清单 6 中的 BytesInputStream 类是不同步的较为普通的字节数组输入流类 。 清单 6. 不同步的字节数组输入流
|
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |