Модераторы: Partizan, gambit
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> BackgroundWorker выполняется дважды 
:(
    Опции темы
_and
Дата 31.1.2008, 05:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Java-developer
*


Профиль
Группа: Участник
Сообщений: 139
Регистрация: 6.8.2004
Где: Новокузнецк

Репутация: нет
Всего: 4



Приветствую всех!
Делаю прогрессбар на форме в методе кнопки выполняю
Код

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
PM MAIL ICQ Jabber   Вверх
mr.DUDA
Дата 31.1.2008, 10:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


3D-маньяк
****


Профиль
Группа: Экс. модератор
Сообщений: 8244
Регистрация: 27.7.2003
Где: город-герой Минск

Репутация: 8
Всего: 232



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


--------------------
user posted image
PM MAIL WWW   Вверх
QryStaL
Дата 31.1.2008, 10:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Intellectual feast
**


Профиль
Группа: Участник
Сообщений: 914
Регистрация: 30.11.2005

Репутация: 10
Всего: 32



Код

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


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


--------------------
I don't need a reason being who I am...
PM MAIL ICQ   Вверх
_and
Дата 4.2.2008, 06:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Java-developer
*


Профиль
Группа: Участник
Сообщений: 139
Регистрация: 6.8.2004
Где: Новокузнецк

Репутация: нет
Всего: 4



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

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

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

PM MAIL ICQ Jabber   Вверх
mr.DUDA
Дата 4.2.2008, 08:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


3D-маньяк
****


Профиль
Группа: Экс. модератор
Сообщений: 8244
Регистрация: 27.7.2003
Где: город-герой Минск

Репутация: 8
Всего: 232



Или 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 раз а не два). Повторяю, ошибка где-то в вашем коде.


--------------------
user posted image
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Прежде чем создать тему, посмотрите сюда:
Partizan
PashaPash

Используйте теги [code=csharp][/code] для подсветки кода. Используйтe чекбокс "транслит" если у Вас нет русских шрифтов.
Что делать если Вам помогли, но отблагодарить помощника плюсом в репутацию Вы не можете(не хватает сообщений)? Пишите сюда, или отправляйте репорт. Поставим :)
Так же не забывайте отмечать свой вопрос решенным, если он таковым является :)


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, mr.DUDA, Partizan, PashaPash.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | .NET для новичков | Следующая тема »


 




[ Время генерации скрипта: 0.0710 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.