2

我的程序一直运行良好,但突然卡在 Process.WaitForExit(); 不继续执行下一个命令。我已经多次运行该程序而没有错误。有谁知道我该如何调试这个,或者有谁知道背后的问题是什么?我的 python.exe 可能有问题吗?谢谢!

public static void Process(string location)
    {
        int ExitCode;
        ProcessStartInfo ProcessInfo;
        Process Process;

        ProcessInfo = new ProcessStartInfo();
        ProcessInfo.FileName = location;
        ProcessInfo.Arguments = Environment.GetFolderPath(Environment.SpecialFolder.Desktop) + 
            "\\parse.py " + Environment.GetFolderPath(Environment.SpecialFolder.Desktop) + "\\cache.cell";
        ProcessInfo.CreateNoWindow = true;
        ProcessInfo.UseShellExecute = false;
        ProcessInfo.RedirectStandardOutput = true;
        ProcessInfo.RedirectStandardError = true;
        Process = Process.Start(ProcessInfo);
        // (...)
        Process.WaitForExit();

        string stderr = Process.StandardError.ReadToEnd();
        string stdout = Process.StandardOutput.ReadToEnd();
        //Console.WriteLine("STDERR: " + stderr);
        //Console.WriteLine("STDOUT: " + stdout);

        using (System.IO.StreamWriter file = new System.IO.StreamWriter(Environment.GetFolderPath(Environment.SpecialFolder.Desktop) + "\\test.txt"))
        {
            file.WriteLine(stdout);
        }
4

1 回答 1

1

在进程退出之前,您的程序不会打印任何内容。如果进程永远不会退出,您将永远看不到任何东西,并且问题将无法调试。

最好在打印时打印

var info = new ProcessStartInfo("msbuild")
{
    UseShellExecute = false,
    CreateNoWindow = true,
    RedirectStandardError = true,
    RedirectStandardOutput = true,            
};

using (var p = Process.Start(info) )
{
    p.ErrorDataReceived += (s, e) => Console.Error.WriteLine(e.Data);
    p.OutputDataReceived += (s, e) => Console.WriteLine(e.Data);
    p.BeginErrorReadLine();
    p.BeginOutputReadLine();
    p.WaitForExit();
}

请参阅如何从 msbuild 输出中保留颜色?

于 2013-07-16T10:58:07.917 回答