0

我们正在尝试实现一个启动进程的程序。但同时最多可以有 2 个进程在内存中运行。如果进程数超过 2,我们会因为许可政策而出现异常。所以基本上我们需要等到 2 个进程结束,然后再开始另外 2 个,直到我们完成。我试图检查内存中是否有 2 个或更多进程然后让线程睡眠,但它似乎不能正常工作

while (Process.GetProcesses().Where(x => x.ProcessName == "myProcessName").Count() >= 2)
{
 Thread.Sleep(100);
}
//Start next process

有任何想法吗?非常感谢!

4

4 回答 4

2

似乎您需要SemaPhore来确保 atmax 2 进程一次运行

于 2013-03-22T10:56:22.833 回答
1

您可以启动进程并等待Exited事件重新启动另一个,如下所示:

using System;
using System.Diagnostics;

namespace ConsoleApplication1 {
    class Program {
        static void StartProcess(string Path) {
            Process Process = Process.Start(Path);
            Process.EnableRaisingEvents = true;
            Process.Exited += (sender, e) => {
                StartProcess(Path);
            };
        }

        static void Main(string[] args) {
            for (int i = 0; i < 2; i++) {
                StartProcess("notepad");
            }
            Console.ReadLine();
        }
    }
}
于 2013-03-22T11:02:29.440 回答
0

我们找到了临时解决方案:

while (true)
  {
    lock (_lock)
    {
      if (Process.GetProcesses().Where(x => x.ProcessName == "processName").Count() < GetProcessNumber)
      {
        //do Smth
        break;
      }
      Thread.Sleep(1000);
    }
  }
于 2013-03-22T13:38:35.040 回答
0

如果先前运行的进程全部退出,这将考虑已经运行的进程并且也只启动新进程。

string processName = "calc";
int processCount = 2;

while ( true )
  {
  while ( Process.GetProcessesByName( processName ).Count() < processCount )
    {
    Process.Start( processName );
    }

  var tasks = from p in Process.GetProcessesByName( processName )
              select Task.Factory.StartNew( p.WaitForExit );
  Task.WaitAll( tasks.ToArray() ); 
  }
于 2013-03-22T11:36:22.633 回答