Статический обработчик события в родительском классе не запускается из Process.Exited во вложенном классе - PullRequest
2 голосов
/ 02 февраля 2012

Каждый раз, когда вызывается CurlFile (), он создает новый объект из класса ProcessObject. Объект ProcessObject запускает новый процесс. Я хочу, чтобы событие Process.Exit в каждом объекте вызывало статический обработчик события в родительском классе, но по какой-то причине он не работает.

class Curl
{
    StringContainer oStrings = new StringContainer();
    private static int _counter = 0;
    private string _curl;

    public Curl()
    {
        //oStartInfo.WindowStyle = System.Diagnostics.ProcessWindowStyle.Hidden;
        _curl = oStrings.Curl;
    }

    public void CurlFile(string _arg)
    {
        ProcessObject oProcessObject = new ProcessObject(_arg, _curl);
    }

    private static void oProcess_Exited(object sender, EventArgs e)
    {
        _counter++;
        if (_counter == 1000)
        {
            MessageBox.Show("here");
        }
    }

    private class ProcessObject
    {
        ProcessStartInfo oStartInfo = new ProcessStartInfo();
        Process oProcess = new Process();

        public ProcessObject(string _arg, string _curl)
        {
            oStartInfo.FileName = _curl;
            oStartInfo.Arguments = _arg;
            oProcess.EnableRaisingEvents = true;
            oProcess.Exited += new EventHandler(oProcess_Exited);
            oProcess = Process.Start(oStartInfo);
        }
    }
}

1 Ответ

1 голос
/ 02 февраля 2012

Во-первых, как упоминает @Will, вам нужно сохранить ссылку на ваши объекты Process, чтобы они не получали GC'd. Примерно так (код не проверен):

class Curl
{
    internal static List<ProcessObject> _processes = new List<ProcessObject>();

    // ....

    private static void oProcess_Exited(object sender, EventArgs e)
    {
        var p = sender as Process;
        if (p != null && _processes.Contains(p))
           _processes.Remove(p);

        _counter++;
        if (_counter == 1000)
        {
            MessageBox.Show("here");
        }
    }

    public ProcessObject(string _arg, string _curl)
    {
        oStartInfo.FileName = _curl;
        oStartInfo.Arguments = _arg;
        oStartInfo.UseShellExecute = false;
        oProcess.EnableRaisingEvents = true;
        oProcess.Exited += new EventHandler(oProcess_Exited);
        oProcess = Process.Start(oStartInfo);
        Curl._processes.Add(oProcess);
    }
}

Кроме того, так как некоторые люди нашли , класс Process может не заметить обнаружение выхода. Я не знаю, верно ли это и для события Exited, но я бы остерегался этого и явно устанавливал UseShellExecute = false;, как и выше.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...