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