話不多說,先上代碼。(純手打,有錯誤請指出來)
//導入按鈕點選事件
private void btn_import_Click(object sender,EventArgs e)
{
//1.綁定需要執行的操作方法
var act = new Action(Import);
act.BeginInvoke(ar => act.EndInvoke(ar), null); //參數null可以作為回調函數的傳回參數
}
//回調函數(此處為無傳回值函數,也可自行改寫)
private void Import()
{
this.btn_import.Enable = false;
this.btn_import.Text = "正在導入...";
DateTime starttime = System.DateTime.now;
try
{
//2.執行導入資料庫操作
//如:sqlhelper.ExecuteNonQuerySqlByTransation(sqlstr);
//3.執行異步操作
this.BeginInvoke(new Action(() =>
{
DateTime endtime = System.DateTime.now;
TimeSpan = ts = endtime.Subtract(starttime);
this.txt_result.Text = "導入了 " + successcount + " 條記錄。";
this.lb_time.Text = "一共消耗了 " + (int)ts.TotalMinutes + " 分鐘, " + ts.Seconds + " 秒。";
this.btn_import.Enable = true;
this.btn_import.Text = "點選開始導入";
}));
}
catch(Exception e)
{ }
}
總結:之是以要使用這種方式來寫,是因為我要執行的資料庫操作是幾十萬條的update語句,如果在click事件裡阻塞或者做Thread.Sleep或一個耗時很長的操作,視窗就會無響應點不動了。故需要用this.BeginInvoke方法來異步執行UI線程的操作,更新界面顯示。
請記住:背景線程避免進行界面控件更新,尤其是存在耗時操作。