Подтвердить что ты не робот

Использование параметров в обработчиках BackgroundWorker

Для передачи данных в BackgroundWorker DoWork я использую отдельный экземпляр класса-оболочки:

MyParams mpar = new MyParams();
...
mpar.Par1 = par1val;
mpar.Par2 = par2val;
mpar.Par3 = par3val;
...
var worker1 = new System.ComponentModel.BackgroundWorker();
worker1.DoWork += new DoWorkEventHandler(worker1_DoWork);
worker1.RunWorkerCompleted += new RunWorkerCompletedEventHandler(worker1_RunWorkerCompleted);
worker1.RunWorkerAsync(mpar);

Затем я могу использовать параметры экземпляра mpar в worker1_DoWork, работая в другом потоке.

void worker1_DoWork(object sender, DoWorkEventArgs e)
 {
      //here we use mpar.Par1, mpar.Par2 and so on
 }

В RunWorkerCompletedEventHandler мы выполняем некоторые посты в потоке пользовательского интерфейса.

Мой вопрос: Можно ли использовать в RunWorkerCompleted обработчик экземпляр mpar, который работал непосредственно перед обработчиком DoWork, и можем ли мы убедиться, что его значения одинаковы в DoWork? Если нет, то каков правильный подход для совместного использования параметров для различных этапов операции BackgroundWorker?

void worker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
    {
        Dispatcher.BeginInvoke((Action)(() =>
        {
            //Can we use the mpar instance here?
        }
        ));
    }
4b9b3361

Ответ 1

Вы можете назначить значение e.Result в worker1_DoWork

static void worker1_DoWork(object sender, DoWorkEventArgs e)
{
    //Do the work
    //...

    e.Result = new MyParams();
}

Затем вы можете получить его в worker1_RunWorkerCompleted в e.Result.

Если вам нужно передать дополнительное значение результата, и вы не хотите помещать объект MyParams в worker1_DoWork: e.Result, то вы можете создать небольшой класс ResultHolder с MyParams и MyResult в качестве свойств и использовать его класс, чтобы передать результат в worker1_DoWork