Maison >développement back-end >C++ >Pourquoi processStartinfo.WaitForexit () est-il stmilé lors de la redirection de standardput ou standarderror?
Résolvez le problème que le processus de processStartin.WaitForexit () est bloqué lorsque la sortie de regroupement ou l'erreur standard de la norme
Lorsque le processus est redirigé vers StandardOutput ou StandardError, il peut y avoir des problèmes. Le tampon interne peut déborder, conduisant à une impasse potentielle ou bloquant votre processus.
Afin d'empêcher de telles impasses et de collecter la sortie de deux flux, envisagez d'utiliser les méthodes de lecture asynchrones suivantes:
Cette méthode asynchrone garantit que le tampon ne débordera pas et empêchera le système de congélation. Vous pouvez maintenant lire et collecter la sortie sans vous soucier des serrures mortes retardées ou potentielles. Le code a été amélioré et comprend le traitement de la sortie d'erreur.
<code class="language-csharp">using System.Diagnostics; using System.Text; using System.Threading; class Program { static void Main(string[] args) { string filename = "TheProgram.exe"; string arguments = "some arguments"; int timeout = 10000; // 10 秒超时 using (Process process = new Process()) { process.StartInfo.FileName = filename; process.StartInfo.Arguments = arguments; process.StartInfo.UseShellExecute = false; process.StartInfo.RedirectStandardOutput = true; process.StartInfo.RedirectStandardError = true; StringBuilder output = new StringBuilder(); StringBuilder error = new StringBuilder(); using (AutoResetEvent outputWaitHandle = new AutoResetEvent(false)) using (AutoResetEvent errorWaitHandle = new AutoResetEvent(false)) { process.OutputDataReceived += (sender, e) => { if (e.Data == null) { outputWaitHandle.Set(); } else { output.AppendLine(e.Data); } }; process.ErrorDataReceived += (sender, e) => { if (e.Data == null) { errorWaitHandle.Set(); } else { error.AppendLine(e.Data); } }; process.Start(); process.BeginOutputReadLine(); process.BeginErrorReadLine(); if (process.WaitForExit(timeout) && outputWaitHandle.WaitOne(timeout) && errorWaitHandle.WaitOne(timeout)) { // 进程成功完成。在此处检查 process.ExitCode。 Console.WriteLine($"输出: {output}"); Console.WriteLine($"错误: {error}"); //添加错误输出 } else { // 超时或发生错误。 Console.WriteLine("进程超时或失败。"); } } } } }</code>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!