C# 进程由于 StandardOutput.ReadToEnd() 和 StandardError.ReadToEnd() 而挂起

C# process hanging due to StandardOutput.ReadToEnd() and StandardError.ReadToEnd()

对于有大量输出或错误的进程,尝试使用简单的方法重定向标准输出和错误

string output = process.StandardOutput.ReadToEnd();
string err = process.StandardError.ReadToEnd();
process.WaitForExit();

将导致程序挂起,并且永远不会真正完成。

事实证明,大量输出填满了 ReadToEnd() 的缓冲区,导致它们永远无法完成。一个对我来说似乎可靠的解决方案是创建一个事件处理程序来逐行对输出做出反应,而不必立即对 output/error 的大块做出反应。

//create event handler
process.OutputDataReceived += new DataReceivedEventHandler(
    (s, e) => 
    { 
        //do something with the output data 'e.Data'
        log.Info("O: "+e.Data);
    }
);
process.ErrorDataReceived += new DataReceivedEventHandler(
    (s, e) => 
    { 
        //do something with the error data 'e.Data'
        log.Info("E: "+e.Data);
    }
);
//start process
process.Start();
process.BeginOutputReadLine();
process.BeginErrorReadLine();
process.WaitForExit();