1. 程式人生 > >C#跨執行緒訪問winform控制元件的方法

C#跨執行緒訪問winform控制元件的方法

方法一:System.Windows.Forms.Control.CheckForIllegalCrossThreadCalls = false; 

不推薦使用這種方式,禁止編譯器對跨執行緒訪問做檢查的方式實現。

 

方法二:使用delegate和invoke

 
  1. private delegate void UpdateLabel2Delegate(string message);

  2. void UpdateLabel2(string message)

  3. {

  4. if (label1.InvokeRequired)

  5. {

  6. UpdateLabel2Delegate md = new UpdateLabel2Delegate(UpdateLabel2);

  7. label1.Invoke(md, new object[] { message });

  8. //label1.BeginInvoke(md, new object[] { message });

  9. }

  10. else

  11. {

  12. label1.Text = message;

  13. }

  14. }

 

 

或者:

 

 
  1. void UpdateLabel2(string message)

  2. {

  3.  this.Invoke((EventHandler)delegate{ this.label1.Text = message;});

  4. }

 

 

或者:(不使用委託方式)

 

 
  1. private void button2_Click(object sender, EventArgs e)

  2. {

  3. Thread thread1 = new Thread(new ParameterizedThreadStart(UpdateLabel2));

  4. thread1.Start("更新Label");

  5. }

  6.  
  7. private void UpdateLabel2(object str)

  8. {

  9. if (label2.InvokeRequired)

  10. {

  11. // 當一個控制元件的InvokeRequired屬性值為真時,說明有一個建立它以外的執行緒想訪問它

  12. Action<string> actionDelegate = (x) => { this.label2.Text = x.ToString(); };

  13. // 或者

  14. // Action<string> actionDelegate = delegate(string txt) { this.label2.Text = txt; };

  15. this.label2.Invoke(actionDelegate, str);

  16. }

  17. else

  18. {

  19. this.label2.Text = str.ToString();

  20. }

  21. }

 

 

方法三:使用BackgroundWorker元件

 

 
  1. private void button4_Click(object sender, EventArgs e)

  2. {

  3. using (BackgroundWorker bw = new BackgroundWorker())

  4. {

  5. bw.RunWorkerCompleted += new RunWorkerCompletedEventHandler(bw_RunWorkerCompleted);

  6. bw.DoWork += new DoWorkEventHandler(bw_DoWork);

  7. bw.RunWorkerAsync("Tank");

  8. }

  9. }

  10. void bw_DoWork(object sender, DoWorkEventArgs e)

  11. {

  12. // 這裡是後臺執行緒, 是在另一個執行緒上完成的, 這裡是真正做事的工作執行緒

  13. // 可以在這裡做一些費時的,複雜的操作

  14. Thread.Sleep(5000);

  15. e.Result = e.Argument + "工作執行緒完成";

  16. }

  17. void bw_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)

  18. {

  19. //這時後臺執行緒已經完成,並返回了主執行緒,所以可以直接使用UI控制元件了

  20. this.label4.Text = e.Result.ToString();

  21. }

--------------------- 作者:believe209 來源:CSDN 原文:https://blog.csdn.net/wangzhen209/article/details/52412205?utm_source=copy 版權宣告:本文為博主原創文章,轉載請附上博文連結!