假设我需要通过Process来执行一个进程,并且需要把进程写入InputStream里面的东西进行读取并分析,并且假设这个进程会产生很多的字符串输出。假定这个进程是curl。
以下代码:
try {
// TODO add your handling code here:
StringBuilder sb = new StringBuilder();
ProcessBuilder pb = new ProcessBuilder("curl","http://www.sina.com.cn");
Process p = pb.start();
InputStream is = p.getInputStream();
BufferedReader reader = new BufferedReader(new InputStreamReader(is),4096);
String line = reader.readLine();
while(line != null){
//sb.append(line);
line = reader.readLine();
}
this.jTextArea1.append(sb.toString());
} catch (IOException ex) {
Logger.getLogger(MainWindow.class.getName()).log(Level.SEVERE, null, ex);
}
在速度上似乎没问题,但是将sb.append(line)
加上去之后,明显变得非常卡,并且CPU占用率特别高。这是为什么呢?
不要自己写,因为你用的 4096 的那个缓存大小有可能不太好。而且你是一行一行地读,BufferedReader 需要查找换行符,这种做法也不高效。
推荐使用 commons-io 的 IOUtils.toString(InputStream, String)
参考代码如下:
另外,我顺便发现 lz 代码的两个问题:
如果还有性能问题,可以用 profiler ,比如 VisualVM 。但是你的代码存在一些基本问题,建议楼主了解并使用一些静态代码检查工具,比如 FindBugs 。
你这里面while(line != null) 可能跳不出来,他会一直是true。你试试看是不是这个问题?