我有一个应用程序
Process.Start()
启动另一个应用程序'ABC'。我想要等到应用程序结束(进程死亡)并继续执行。我该怎么做呢?
可能同时运行应用程序'ABC'的多个实例。
我有一个应用程序
Process.Start()
启动另一个应用程序'ABC'。我想要等到应用程序结束(进程死亡)并继续执行。我该怎么做呢?
可能同时运行应用程序'ABC'的多个实例。
当前回答
我在我的申请中做了以下几点:
Process process = new Process();
process.StartInfo.FileName = executable;
process.StartInfo.Arguments = arguments;
process.StartInfo.ErrorDialog = true;
process.StartInfo.WindowStyle = ProcessWindowStyle.Minimized;
process.Start();
process.WaitForExit(1000 * 60 * 5); // Wait up to five minutes.
有一些额外的功能,你可能会发现有用的…
其他回答
我在我的申请中做了以下几点:
Process process = new Process();
process.StartInfo.FileName = executable;
process.StartInfo.Arguments = arguments;
process.StartInfo.ErrorDialog = true;
process.StartInfo.WindowStyle = ProcessWindowStyle.Minimized;
process.Start();
process.WaitForExit(1000 * 60 * 5); // Wait up to five minutes.
有一些额外的功能,你可能会发现有用的…
就像乔恩·斯基特说的,使用这个过程。退出:
proc.StartInfo.FileName = exportPath + @"\" + fileExe;
proc.Exited += new EventHandler(myProcess_Exited);
proc.Start();
inProcess = true;
while (inProcess)
{
proc.Refresh();
System.Threading.Thread.Sleep(10);
if (proc.HasExited)
{
inProcess = false;
}
}
private void myProcess_Exited(object sender, System.EventArgs e)
{
inProcess = false;
Console.WriteLine("Exit time: {0}\r\n" +
"Exit code: {1}\r\n", proc.ExitTime, proc.ExitCode);
}
参考微软的例子: (https://learn.microsoft.com/en - us/dotnet/api/system.diagnostics.process.enableraisingevents?view=netframework - 4.8)
最好的设置是:
myProcess.EnableRaisingEvents = true;
否则代码将被阻塞。 也不需要额外的属性。
// Start a process and raise an event when done.
myProcess.StartInfo.FileName = fileName;
// Allows to raise event when the process is finished
myProcess.EnableRaisingEvents = true;
// Eventhandler wich fires when exited
myProcess.Exited += new EventHandler(myProcess_Exited);
// Starts the process
myProcess.Start();
// Handle Exited event and display process information.
private void myProcess_Exited(object sender, System.EventArgs e)
{
Console.WriteLine(
$"Exit time : {myProcess.ExitTime}\n" +
$"Exit code : {myProcess.ExitCode}\n" +
$"Elapsed time : {elapsedTime}");
}
我有一个案例。关闭属于进程的窗口后,HasExited没有改变。所以Process.WaitForExit()也不起作用。我必须监视Process。在像这样关闭窗口后,返回为false:
while (!_process.HasExited && _process.Responding) {
Thread.Sleep(100);
}
...
也许这对某些人有帮助。
使用Process.WaitForExit吗?或订阅进程。退出事件如果你不想阻止?如果这不能满足你的要求,请给我们更多的信息。