WPF UI线程安全性

WPF的UI控件基于DispatcherObject,其Dispatcher管理消息循环。在多线程操作UI时,使用Invoke(同步)和BeginInvoke(异步)确保线程安全。Invoke以高优先级直接执行,而BeginInvoke将操作放入消息队列。这与WinForm的Control.Invoke和BeginInvoke类似,但WPF进行了封装。示例中展示了Dispatcher的使用,强调Application.Run实际运行Dispatcher.Run。
摘要由CSDN通过智能技术生成

WPF所有的控件都是继承于 DispatcherObject, 在DispatcherObject 有个属性是Dispatcher(每个UI线程创建的所有UI都是同一个), 这个Disapatcher对象管理了Windows窗口的消息循环,跟VC++ /WinForm窗口一样,WPF的也要有消息循环,只不过WPF对所有的消息进行了特殊的封装,将MSG转换为DispatcherOperation, Dispacher对象中包含了一个DispatcherOperation的列表,该列表就是我们之前理解的消息队列。

在进行UI多线程操作的时候,WPF 中所有的控件可以执行UiObject.Dispatcher.Invoke()/BeginInvoke(),其中Invoke是同步操作, BeginInvoke是异步操作,在执行Invoke的时候实际上执行的也是BeginInvoke类似的过程,只不过是用了特殊的优先级-DispatcherPriority.Send,这是一个特殊的Priority,在接收到该优先级的时候不会把消息(DispatcherOperation)放到消息队列,而是会直接执行该消息,注意WinForm是通过Control类的Invoke和BeginInvoke来实现多线程UI操作的,WPF跟WinForm类似,只不过进行了一定的封装。

一个简单的例子:

TextBlock textBlock = new TextBlock() { Text = "1" }; 
Thread thread = new Thread(new ThreadStart(() => 
    { 
        //做一些耗时操作,这里用线程休眠10秒来模拟 
         Thread.Sleep(TimeSpan.Fr
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值