Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > .NET для новичков > BackgroundWorker выполняется дважды


Автор: _and 31.1.2008, 05:26
Приветствую всех!
Делаю прогрессбар на форме в методе кнопки выполняю
Код

private void btnImport_Click(object sender, EventArgs e)
        {
            this.pbImportProgress.Value = this.pbImportProgress.Minimum = 0;
            this.pbImportProgress.Maximum = 100;
            this.pbImportProgress.Step = 1;
            Console.WriteLine("Запуск BW");
            this.bgWorker.RunWorkerAsync(dgvReadedData.Rows);
        }

в событии DoWork выполняется
Код
private void bgWorker_DoWork(object sender, DoWorkEventArgs e)
        {
            Console.WriteLine("Работает BW DateTime.Now: " + DateTime.Now);
            for (int i = 0; i < 100; i++)
            {
                Console.WriteLine("Step " + i + " DateTime.Now: " + DateTime.Now);
                Thread.Sleep(100);
            }
        }

в консоли выводится
Код

Запуск BW
Работает BW DateTime.Now: 31.01.2008 9:17:28
Step 0 DateTime.Now: 31.01.2008 9:17:28
Step 1 DateTime.Now: 31.01.2008 9:17:28
Step 2 DateTime.Now: 31.01.2008 9:17:28
...
Step 97 DateTime.Now: 31.01.2008 9:17:37
Step 98 DateTime.Now: 31.01.2008 9:17:38
Step 99 DateTime.Now: 31.01.2008 9:17:38
Работает BW DateTime.Now: 31.01.2008 9:17:38
Step 0 DateTime.Now: 31.01.2008 9:17:38
Step 1 DateTime.Now: 31.01.2008 9:17:38
Step 2 DateTime.Now: 31.01.2008 9:17:38
...
Step 98 DateTime.Now: 31.01.2008 9:17:48
Step 99 DateTime.Now: 31.01.2008 9:17:48
Завершение работы BW
Завершение работы BW

вот я не могу понять почему два раза цикл работает
версия .NET - 2.0.50727.42

Автор: mr.DUDA 31.1.2008, 10:13
Сделал аналогичный код в пустом проекте, всё работает ок. Следовательно, ошибка где-то ещё.

Автор: QryStaL 31.1.2008, 10:25
Код

Завершение работы BW    
Завершение работы BW


В коде этого места нет. Кинь более полный кусок ))

Автор: _and 4.2.2008, 06:15
Цитата(QryStaL @ 31.1.2008,  15:25)
В коде этого места нет. Кинь более полный кусок ))

Приветствую, 
вот тот кусок все равно в нем нет ничего примечательного
Код

private void bgWorker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
        {
            Console.WriteLine("Завершение работы BW");
        }

Автор: mr.DUDA 4.2.2008, 08:20
Или btnImport_Click два раза выполняется, или одно из двух. Точку останова пробовали ставить? Может ещё откуда-нибудь запускается background worker?

Добавлено через 3 минуты и 36 секунд
Вот пример:
Код
using System;
using System.ComponentModel;
using System.Threading;

class Program
{
    static void Main()
    {
        BackgroundWorker w = new BackgroundWorker();
        w.DoWork += new DoWorkEventHandler(w_DoWork);
        w.RunWorkerCompleted += new RunWorkerCompletedEventHandler(w_RunWorkerCompleted);
        w.RunWorkerAsync();

        Console.ReadLine();
    }

    static void w_DoWork(object sender, DoWorkEventArgs e)
    {
        Console.WriteLine("Работает BW DateTime.Now: " + DateTime.Now);
        for (int i = 0; i < 100; i++)
        {
            Console.WriteLine("Step " + i + " DateTime.Now: " + DateTime.Now);
            Thread.Sleep(100);
        }
    }

    static void w_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
    {
        Console.WriteLine("Завершение работы BW");
    }

}


Обычное консольное приложение с добавленной ссылкой на System.Windows.Forms. Всё работает как надо (в DoWork приходит 1 раз а не два). Повторяю, ошибка где-то в вашем коде.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)