http://www.rgagnon.com/javadetails/java-0014.html但在单独的线程中进行错误流处理为什么 - 请参阅 javadoc http://docs.oracle.com/javase/1.5.0/docs/api /java/lang/Process.html
由于部分原生平台只为标准输入输出流提供有限的缓冲区大小,未能及时写入子进程的输入流或读取输出流可能会导致子进程阻塞,甚至死锁。
package utl;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.FileReader;
public class ReadStreamAsync extends Thread {
private BufferedReader is = null;
private int toOut = 0;//0 none, 1 out, 2 err
private boolean toSB = false;
private StringBuffer sb = null;
public ReadStreamAsync(BufferedReader is, int toOut, boolean toSB){
if(is == null)throw new NullPointerException("stream is null");
this.is = is;
this.toSB = toSB;
this.toOut = toOut;
if(toSB)sb = new StringBuffer();
start();
}
public void run(){
try{
int i;
while((i = is.read()) > -1){
if(toOut == 1){
System.out.print((char)i);
}else if(toOut ==2){
System.err.print((char)i);
}
if(toSB)sb.append((char)i);
}
}catch(Exception e){
e.printStackTrace();
}finally{
try{
is.close();
}catch(Exception e){
e.printStackTrace();
}
}
}
public String getRead(){
return sb.toString();
}
/**
* test code
* @param args
*/
public static void main(String[] args) {
try{
BufferedReader fis = new BufferedReader(new FileReader("c:/tmp/sample1.txt"));
ReadStreamAsync t = new ReadStreamAsync(fis, 1, false);
t.join(1000);
System.out.println("\nAll :");
fis = new BufferedReader(new FileReader("c:/tmp/sample1.txt"));
t = new ReadStreamAsync(fis, 0, true);
t.join(1000);
System.out.println(t.getRead());
}catch(Exception e){
e.printStackTrace();
}
}
}
这就是你可以使用它的方式
Process proc = procBldr.start();
//props is a java.util.properties that was previosly loaded from some stream
System.out.println(" Cmd start f :" + cmdStartFolder);
System.out.println(" Cmd :" + lstCmds);
BufferedReader isO = new BufferedReader (new InputStreamReader(proc.getInputStream()));
BufferedReader isE = new BufferedReader (new InputStreamReader(proc.getErrorStream()));
asynO = new com.enstage.commonutil.file.ReadStreamAsync(isO, 1, true);
asynE = new com.enstage.commonutil.file.ReadStreamAsync(isE, 1, true);
if("1".equals(props.getProperty("waitFor")){
proc.waitFor();//maybe parameterize this not required everywhere only good for short processes
}
String sleepAfterWait = props.getProperty("sleepAfterWait");
try {
Thread.sleep(500);//some sleep after telling windows to do things with files is good
if(sleepAfterWait != null){
int i = Integer.parseInt(sleepAfterWait);
Thread.sleep(i);
}
} catch (Exception e) {
System.out.println("sleep err :" + e );
e.printStackTrace();
}
asynE.join();
asynO.join();
String checkString = props.getProperty("checkString");
System.out.println("\n done " );
//asynE.getRead();//if you want error out as a string
if(checkString != null){
System.out.println("checkString :" + checkString );
String out = asynO.getRead();
if(out.indexOf(checkString) > -1){
System.out.println(" Check string found!" );
}else{
System.err.println(" *** Check string not found ***!" );
}
}
已经使用它成功地在 .bat 和其他进程中调用 xcopy