跨线程调用控件之MethodInvoker

本文介绍了一种在C#中实现跨线程更新用户界面的方法。通过创建后台线程并利用委托Invoke或BeginInvoke来安全地修改主线程中的UI元素,如Label文本。这种方法避免了因直接从非UI线程修改UI组件而引发的应用程序崩溃。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

这是一部分重要的代码,用VS2005通过。

使用到两个控件,一个按钮button1,一个标签label1。

       private voidbutton1_Click(objectsender,EventArgse) 

        {

           Thread thread=new Thread(new ThreadStart(myname));

            thread.IsBackground=true;

            thread.Start();

            //启动一个线程。

        }

       private voidmyname()

        {

          MethodInvoker mi =new MethodInvoker(hello);//创建一个委托,hello是该委托所托管的代码,必须是声明为void的。

           Invoke(mi);//同步执行委托。               

           //BeginInvoke(mi);异步执行委托。

        }

       private void hello()

        {

            label1.Text ="我是跨线程的!";

        }

  有不不正确的地方,请各位一定要指出,我可不想误导人,也不想被自己误导。

 

 

PS: 写完后我发现他处早就有解释,比我的还详细,领教了。

故补充以下代码:

        private Thread myThread;
       privatevoid Form1_Load(object sender,EventArgs e)
        {
            myThread =new Thread(new ThreadStart(RunsOnWorkerThread));
            myThread.Start();
        }
       privatevoid RunsOnWorkerThread()
        {
           //DoSomethingSlow();
           string pList ="myThread线程调用UI控件";
            label1.BeginInvoke(new System.EventHandler(UpdateUI), pList);
        }
       //直接用System.EventHandler,没有必要自定义委托
       private void UpdateUI(object o, System.EventArgs e)
        {
          //UI线程设置label1属性
            label1.Text = o.ToString() +"成功!";
   
    }

在码农的生活中,很多级码农都有这样的经历,会被一个小小的技术问题拦住,然后进度跟不上了,被老板XXXX一大通了。心情不爽了。 好吧,这个曾经是我遇到拦路虎之一。但事实上不是什么大技术。技术就是一层纸,破了就破了。 这是一个关于如何跨窗体操作控件或过程的一个例子。比如,你想用窗体A的按键来执行窗体B的文本框变色。 Imports System Imports System.Threading Imports System.Text Public Class Form1 Private Sub Form1_Load(sender As Object, e As EventArgs) Handles Me.Load CheckForIllegalCrossThreadCalls = False '不写这行,会出错,不允许线程的数据写到TextBox1.Text 中去。 Form2.Show() End Sub Private Sub form1_FormClosing(sender As Object, e As EventArgs) Handles Me.FormClosing ' If runThread.IsAlive = True Then runThread.Abort() End Sub Private Sub Button2_Click(sender As Object, e As EventArgs) Handles Button2.Click '用的是委托方式 Me.Invoke(New MethodInvoker(AddressOf THREAD2)) End Sub Private Sub THREAD2() Static j As Integer j = j + 1 TextBox1.Text = " 这是 [线程] 操作" & vbCrLf & _ " Button2被点了: " & j & " 次" & vbCrLf & "要求是from2.textbox.text= textbox1.text 。[问题]但为什么不能成功显示呢?" End Sub Private Sub TextBox1_TextChanged(sender As Object, e As EventArgs) Handles TextBox1.TextChanged Form2.TextBox1.Text = TextBox1.Text End Sub Private Sub Button3_Click(sender As Object, e As EventArgs) Handles Button3.Click Static j As Integer j = j + 1 TextBox1.Text = " 这是 [非线程] 操作" & vbCrLf & _ "Button3 点击了: " & j & " 次" & vbCrLf & _ "要求是from2.textbox.text= textbox1.text, 可以成功显示,这个是对的。" End Sub End Class
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值