2

我在 C# 中调用一个可执行文件。当可执行文件运行时,它会写出到控制台,以便 C# 代码获取控制台输出并将其写入文本文件。当崩溃发生时,会发生几件事。

1)文本文件的输出没有完全写出。2)可执行进程似乎完全运行通过,因为它生成报告就像成功运行一样。

我怀疑这次崩溃的原因是因为我是如何写出文件的。

更新:-至于崩溃,出现一个对话框,说“经理遇到问题需要关闭。对于给您带来的不便,我们深表歉意。” 然后它有一个确定按钮。当您单击“确定”时,会出现一个对话框,询问我是否要再次启动管理器。

  • 调用可执行文件的管理器应用程序是单线程的。可执行文件可以多线程运行。

以下是通话的一小段:

  // Set up process to redirect standard output and standard error to
  // a file.
     process.StartInfo.UseShellExecute = false;
     process.StartInfo.RedirectStandardOutput = true;
     process.StartInfo.RedirectStandardError = true;
     FileInfo ofi = new FileInfo(outputPath);
     FileStream ofs = ofi.OpenWrite();
     StreamWriter sw = new StreamWriter(ofs);
     WriteToTextWriterEventHandler wtsweh = new WriteToTextWriterEventHandler(sw);
     DataReceivedEventHandler handler = wtsweh.HandleDataReceived;
     process.OutputDataReceived += handler;
     process.ErrorDataReceived += handler;
     //

     statusAcceptor.ReportStatus("Running process.");
     process.Start();
     process.BeginOutputReadLine();
     process.BeginErrorReadLine();

     statusAcceptor.ReportStatus("Waiting for process to complete.");
     process.WaitForExit();
     int processExitCode = process.ExitCode;
     process.Close();
     sw.Close();


  // 
  private class WriteToTextWriterEventHandler
  {
      private TextWriter tw;

      public WriteToTextWriterEventHandler(TextWriter tw)
      {
          this.tw = tw;
      }

      public void HandleDataReceived(object sendingProcess,
         DataReceivedEventArgs outLine)
      {
          // Collect the sort command output.
          if (!String.IsNullOrEmpty(outLine.Data))
          {
              tw.Write(Environment.NewLine + outLine.Data);
          }
      }
  }
4

5 回答 5

1

您遇到的崩溃是什么?.Net 异常?

文件未完全写入可能是因为您没有将流刷新到文件中然后关闭它。

我认为您对标准输出和错误输出消息使用相同的流可能是一个问题。这可能会导致并发问题。

于 2008-12-09T20:05:10.193 回答
1

尝试在 tw.Write 之后添加刷新。这应该会导致生成完整的输出直到出现故障点,其中可能包括来自可执行文件的错误消息(如果那是什么崩溃了?)

于 2008-12-09T22:27:39.937 回答
1

如果您将调试器附加到崩溃进程,您将确切知道它崩溃的原因。这是调试崩溃的详细教程:http: //blogs.msdn.com/kirillosenkov/archive/2008/12/07/how-to-debug-crashes-and-hangs.aspx

于 2008-12-10T04:11:55.077 回答
1

它可能在您的处理程序中。您应该放入逻辑来处理流处理程序抛出的异常,并且应该放入一种机制以确保在对进程调用 close 之前正确关闭流处理程序。由于事件处理程序和 process.close 的时间问题,这样的问题很难确定,因此其他海报无法重现它并不让我感到惊讶。但我已经看到它在行动。问题是 EventHandler 一直处于活动状态,直到通过调用 cancelErrorRead 或 cancelOutputRead 将其关闭或进程退出。好吧,如果它仍然忙于从进程的最后刷新一些输出,而主线程使其进入 Process.Close...BOOM

于 2008-12-10T13:26:16.113 回答
0

我已经用许多不同的可执行文件测试了你的代码,但无法让它按照你描述的方式崩溃。也许这是您正在执行的过程的问题?

于 2008-12-09T22:38:42.770 回答