缓冲介绍
缓冲区是一块特定的内存区域。开辟缓冲区的目的是通过缓解应用程序上下层之间的性能差异,提高系统的性能。在日常生活中,缓冲的一个典型应用是漏斗。
缓冲最常用的场景就是提高I/O的速度。为此,JDK内不少I/O组件都提供了缓冲功能。比如,当使用FileWriter时,进行文件写操作的代码如下:
public static final int CIRCLE=100000;
@Test
public void testFileWriter() throws IOException {
Writer writer = new FileWriter(new File("file.txt"));
long begin=System.currentTimeMillis();
for (int i = 0; i < CIRCLE; i++) {
writer.write(i);
}
writer.close();
System.out.println("testFileWriter spend:"+(System.currentTimeMillis()-begin));
}
为进行I/O优化,可以为FileWriter加上缓冲:
public static final int CIRCLE=100000;
@Test
public void testFileWriterBuffer() throws IOException {
Writer writer = new BufferedWriter(new FileWriter(new File("file.txt")));
long begin=System.currentTimeMillis();
for (int i = 0; i < CIRCLE; i++) {
writer.write(i);
}
writer.close();
System.out.println("testFileWriterBuffer spend:"+(System.currentTimeMillis()-begin));
}
以上代码使用BufferedWriter为FileWriter对象增加缓冲功能。
public BufferedWriter(Writer out)
public BufferedWriter(Writer out, int sz) //允许指定缓冲区的大小
另一个有用的缓冲组件是BufferedOutputStream,使用BufferedOutputStream可以包装所有的OutputStream,为其提供缓冲功能,提高输出流的效率。和BufferedWriter功能类似。
缓存介绍
缓存的主要作用是暂存数据处理结果,并提供下次访问使用。
最简单的缓存可以直接使用HashMap实现。当然,这样做会遇到很多问题,比如,何时清理无效的数据;如何防止缓存数据过多而导致内存溢出等。一个稍好的替代方案是直接使用WeakHashMap,它使用弱引用维护一张哈希表,从而避免了潜在的内存溢出问题。
缓存框架
目前有很多基于Java的缓存框架,比如EHCache、OSCache和JBossCache等。EHCache缓存缓存出自Hibernate,是Hibernate框架默认的数据缓存解决方案;OSCache缓存是有OpenSymphony设计的,它可以用于缓存任何对象,甚至是缓存部分JSP页面或者HTTP请求;JBossCache是由JBoss开发,可用于JBoss集群间数据共享的缓存框架。