当前位置: 代码迷 >> J2EE >> BufferedReader,BufferedWriter性能测试,结果咋就大失所望了呢
  详细解决方案

BufferedReader,BufferedWriter性能测试,结果咋就大失所望了呢

热度:561   发布时间:2016-04-17 23:31:31.0
BufferedReader,BufferedWriter性能测试,结果咋就失望了呢?
说明:
          1.d:/iotest/1.txt文件是一个纯文本文件,大小为25.4M;
          2.execute1方法不使用缓冲区,execute2方法使用缓冲区;
          3.execute1方法和execute2方法分别循环10次;

结果:
          execute1方法循环10次所需时间4.059s
          execute2方法循环10次所需时间5.730s

上代码:

package io;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.Reader;
import java.io.Writer;

import org.junit.Test;

public class Reader_Writer_Test {
@Test
public void testExecute() {
for (int i = 0; i <10; i++) {
execute1();
//execute2();
}

}

/**
 * 简单描述:不使用缓冲区BufferedReader,BufferedWriter
 * <p> 
 */
private static void execute1() {
Reader fileReader = null;
Writer fileWriter = null;
try {
fileReader = new FileReader("d:/iotest/1.txt");
// fileReader = new FileReader(new File("d:/iotest/reader.txt"));
fileWriter = new FileWriter("d:/iotest/111.txt");
char[] cbuf = new char[1024*1024];
int lenth = 0;
while ((lenth = fileReader.read(cbuf)) != -1) {
fileWriter.write(cbuf, 0, lenth);
fileWriter.flush();
}
fileWriter.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (null != fileReader) {
fileReader.close();
}

if (null != fileWriter) {
fileWriter.close();
}

} catch (IOException e) {
e.printStackTrace();
}
}
}

/**
 * 简单描述:使用缓冲区BufferedReader,BufferedWriter
 * <p> 
 */
private static void execute2() {
BufferedReader bufReader = null;
BufferedWriter bufWriter = null;
try {
bufReader = new BufferedReader(new FileReader("d:/iotest/1.txt"));
bufWriter = new BufferedWriter(new FileWriter("d:/iotest/222.txt"));
String line = null;
while ((line = bufReader.readLine()) != null) {
bufWriter.write(line);
bufWriter.flush();
}

} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (null != bufReader) {
bufReader.close();
}

if (null != bufWriter) {
bufWriter.close();
}

} catch (IOException e) {
e.printStackTrace();
}
}
}

}

------解决思路----------------------
首先未加缓冲的是每次读取1K,然后写入输出流。加缓冲区的是每次读取一行,flush后写入输出流。一行的数据没有1K吧,所以加了缓冲区的反而没有不加缓冲区的快。把flush去掉,缓冲区满了它会自动写入输出流。