C#多線(xiàn)程窗體控件安全訪(fǎng)問(wèn) 收藏
C#多線(xiàn)程窗體控件安全訪(fǎng)問(wèn)
--------------------------------------------------------------------------------
C# 2.0 為了線(xiàn)程安全,不充許子線(xiàn)程直接訪(fǎng)問(wèn)窗體中的控件
如果在子線(xiàn)程中直接訪(fǎng)問(wèn)說(shuō)窗體控件,編譯器會(huì )提示,控件不是
由該線(xiàn)程創(chuàng )建的.
那么在子線(xiàn)程中如何訪(fǎng)問(wèn)窗體中的控件呢?
在窗體的構造函數中加入這一句
Control.CheckForIllegalCrossThreadCalls = false;
子線(xiàn)程就可以直接訪(fǎng)問(wèn)窗體中的控件了,不過(guò)這樣線(xiàn)程是非安全的.
而默認Control.CheckForIllegalCrossThreadCalls=true;(捕獲線(xiàn)程錯誤調用)
這時(shí)可以用Invoke
如下:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Threading;
namespace Project2
{
public partial class Form1 : Form
{
private BackgroundWorker backgroundWorker1;
protected delegate void UpdateControlText(string strText);//定義一個(gè)委托
//定義更新控件的方法
protected void updateControlText(string strText)
{
this.label1.Text = strText ;
return;
}
public Form1()
{
//Control.CheckForIllegalCrossThreadCalls = false;
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
Thread ff = new Thread( new ThreadStart ( x2));
ff.Start();
}
private void x1()//線(xiàn)程安全的訪(fǎng)問(wèn)窗體控件
{
for (int i = 0; i < 1000; i++)
{
long xx = Convert.ToInt32(this.label1.Text);
if (this.InvokeRequired)
{
UpdateControlText update = new UpdateControlText(updateControlText);//用更新控件的方法updateControlText實(shí)例化一個(gè)委托update
this.Invoke(update, Convert.ToString(++xx));//調用窗體Invoke方法
}
else
{
this.label1.Text = Convert.ToString(++xx);
}
}
}
}
}
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請
點(diǎn)擊舉報。