关于C#下面的Invoke 和在WPF中使用的Dispatcher.Invoke的区别

在此重新学习一下Dispatcher.Invoke的定义:
从主 UI 线程派生的后台线程不能更新的内容 
Button UI 线程上创建。 为了使后台线程访问的内容属性的 
Button, ,后台线程必须将工作委托给 
Dispatcher 与 UI 线程关联。 这通过使用实现 
Invoke 或 
BeginInvoke。 Invoke 是同步和

BeginInvoke 是异步的。
 

 

 

主要原因是C#是主线程在运行,而WPF是代码和界面分开的两个线程在运行。

第一种方法:

WinForms 

privatedelegatevoidUpdateUiTextDelegate(Control control, stringtext);
privatevoidUpdateUiText(Control control, stringtext)
{
if(InvokeRequired)
{
Invoke(newUpdateUiTextDelegate(UpdateUiText), newobject[] {control, text});
return;
}
control.Text = text;
}

 

WPF

privatevoidUpdateUiText(Control control, stringtext)
{
if(!Dispatcher.CheckAccess())
{
Dispatcher.Invoke(DispatcherPriority.Send, newUpdateUiTextDelegate(UpdateUiText), control, text);
return;
}
control.Text = text;
}

 

第二种方法:

C#:

        private delegate void SetRichTextBoxReceiveCallBack(string str);
        private SetRichTextBoxReceiveCallBack setRichTextBoxReceiveCallBack;

 

        richTextBoxRecv.Invoke(setRichTextBoxReceiveCallBack, Encoding.UTF8.GetString(dataRead.msg, 0, recv));

        使用委托进行的!

WPF:

        private void showMessage(string msg)
        {
            Action action = () => richTextBoxRecv.AppendText(msg + "\r\n");
            if (System.Threading.Thread.CurrentThread !=
            richTextBoxRecv.Dispatcher.Thread)
            {
                richTextBoxRecv.Dispatcher.Invoke
                    (System.Windows.Threading.DispatcherPriority.Normal,
                    action);
            }
            else
            {
                action();
            }
        }

 

        showMessage(Encoding.UTF8.GetString(dataRead.msg, 0, recv).Trim());

      也是使用委托,只是进行改造。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值