首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

通过反射修改DispatcherObject中的_dispatcher字段以跨线程修改DispatcherObject对象的属性?

DispatcherObject是WPF框架中的一个基类,它提供了跨线程操作UI元素的能力。_dispatcher字段是DispatcherObject类中的私有字段,它用于存储与Dispatcher关联的DispatcherSynchronizationContext实例。

要通过反射修改DispatcherObject中的_dispatcher字段以跨线程修改DispatcherObject对象的属性,可以按照以下步骤进行操作:

  1. 使用反射获取DispatcherObject类型的字段信息,包括名为"_dispatcher"的私有字段。
  2. 使用反射获取DispatcherObject对象的类型信息,通过类型信息创建对象实例。
  3. 使用反射获取DispatcherSynchronizationContext类型的字段信息,以便在后续步骤中修改DispatcherObject对象的_dispatcher字段。
  4. 使用反射获取DispatcherSynchronizationContext类型的构造函数信息,以便在后续步骤中创建DispatcherSynchronizationContext对象。
  5. 使用反射获取DispatcherSynchronizationContext类型的属性信息,包括名为"Dispatcher"的公共属性。
  6. 使用反射获取Dispatcher类型的字段信息,以便在后续步骤中修改DispatcherSynchronizationContext对象的Dispatcher字段。
  7. 使用反射获取Dispatcher类型的构造函数信息,以便在后续步骤中创建Dispatcher对象。
  8. 使用反射获取Dispatcher类型的属性信息,包括名为"FromThread"的公共属性。
  9. 通过反射修改DispatcherObject对象的_dispatcher字段,将其设置为新创建的DispatcherSynchronizationContext对象。

需要注意的是,这种方法属于反射调用私有字段和类型,属于一种hack方式,不推荐在正式的开发中使用。正确的方式是利用Dispatcher类提供的Invoke或BeginInvoke方法在UI线程上执行操作,以确保线程安全性和正确性。

腾讯云相关产品和产品介绍链接地址请参考腾讯云官方文档或咨询腾讯云官方客服。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

WPF 那些可线程访问 DispatcherObject(WPF Free Threaded Dispatcher Object)

; } 于是我们发现,实际上 Dispatcher 属性虽然在 DispatcherObject 对象创建时候会赋值,但实际上提供了多种方法来修改值。...通过阅读 DispatcherObject 源码,我们可以知道 DispatcherObject 其实是允许线程访问,它只是在刚刚创建时候如果没有其他额外方法调用使得 Dispatcher 属性改变...强制让一个 DispatcherObject 线程访问 从前面的各种源码分析来看,使用常规方法让任意一个对象进行线程访问几乎是不可能了。剩下就只是做一些邪恶事情了,比如 —— 反射。...可以反射调用 DetachFromDispatcher 方法,将 Dispatcher 属性值清空,这样对象将可以所有线程访问。...可以反射直接修改 _dispatcher 字段值,改为目标线程 Dispatcher。这样做法只是切换了一个线程,效果和调用 MakeSentinel 是一样

1K20

WPF Application.Current.Dispatcher Dispatcher 属性一定不会为 null

在 WPF 程序,可能会存在 Application.Current.Dispatcher.Xxx 这样代码让一部分逻辑回到主 UI 线程。...Dispatcher 属性仅仅是在获取 _dispatcher 字段值,因此我们只需要看 _dispatcher 字段赋值时机,以及所有给 _dispatcher 赋值代码。...由于 _dispatcher 字段是私有字段,所以仅需调查这个类本身即可找到所有的赋值时机。(反射等非常规手段需要排除在外,因为这意味着开发者是逗比——自己闯祸不能怪 WPF 框架。)...如果你还说拿到了 null,那就检查是否有逗比程序员通过反射或其他手段将 _dispatcher 字段改为了 null 吧…… Application.Current 静态属性 关于 Application.Current...欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://blog.walterlv.com ),不得用于商业目的,基于本文修改作品务必相同许可发布。

35420
  • WPF消息机制(一)- 让应用程序动起来

    Post到特定窗口所在线程消息队列,应用程序消息循环再不断从消息队列当中获取消息,然后再派发给特定窗口类窗口过程来处理,在窗口过程完成一次用户交互。...DispactherObject以及Dispatcher在WPF系统作用。...WPF大部分对象都是从DispatcherObject派生,从这里派生对象具有一个明显特征,那就是:修改对象时所在线程,和创建对象时所在线程必须为同一个线程,这就是微软所谓线程亲缘性(Thread...从DispatcherObject派生类型继承三个重要成员:Dispatcher属性,CheckAccess(), VerifyAccess()方法。其中后面两个方法就是检验线程亲缘性。...通过调用堆栈可以看出,蓝色部分是启动了一个线程,VisualStudio在Host进程当中运行当前应用程序;红色部分是从Application.Main函数开始执行,经过几个函数到达Dispatcher.Run

    1.4K90

    2018-12-13-不要相信那些事件引发者

    我们都知道wpfDispatcherObject,必须在创建它Dispatcher上执行,而由于C#事件机制,这个调用线程(及关联Dispatcher控制权交给了事件引发者。...所以不注意小伙伴就常常会出现这样情况: 事件引发者时而从主线程Invoke,时而从后台线程Invoke。 事件监听者概率性出现UI元素线程调用问题。 怎么办呢?...最佳实践:我们在事件注册函数不相信那些事件引发者,(路由事件等确定是UI线程引发事件除外),针对UI元素调用使用Dispatcher.Invoke,针对耗时操作使用异步方法。...如果事件引发是来自主线程,注册方法也是UI相关,那么如果在登陆后在后台线程注册,就会出现线程访问问题哦 ---- 本文会经常更新,请阅读原文: https://xinyuehtx.github.io...欢迎转载、使用、重新发布,但务必保留文章署名黄腾霄(包含链接: https://xinyuehtx.github.io ),不得用于商业目的,基于本文修改作品务必相同许可发布。

    35220

    windowsform和wpf(winform和wpf我选哪个)

    线程处理 在WinForm程序开发时,最头疼一个问题就是,worker线程修改控件属性而导致程序崩溃,而且这种非法操作并不是每次都失败。...WinForm控件提供了InvokeRequired属性来判断当前线程是不是控件创建线程。问题是当控件树很深是,这个属性会比较慢。 WPF开始设计时候,就考虑到了多线程问题。...大部分WPF类都继承于DispatcherObjectDispatcherObject实际就是对Dispatcher一个简单封装。...而通过WPF控件Content Model和Layout系统,WPF控件可以包括任何类型控件,甚至.Net CLR对象。...而WPF在这方面通过XAML可以简单把相关属性联系起来,通过Extension可以实现复杂绑定关系。

    1.3K10

    WPFDispatcher初步探讨

    类,而DispatcherObject包含了一个公共属性Dispatcher。...实际上不仅仅是Window类,其他控件也都继承自DispatcherObject,因此他们在初始化时都自动赋值了Dispatcher属性,并且都指向同一个UI线程所拥有的Dispatcher对象。...貌似访问是运行myFun线程Dispatcher,看起来是有点古怪,不过你只要知道this指的是MainWindow实例对象,那么MainWindow这个类实例对象Dispatcher是UI线程拥有的对象...} } 用debug调试方式,你会发现在MainWindow构造函数下函数获得dsp非空,并且通过Equals()方法发现dsp就是this.Dispatcher。...官网透露资料里,告诉我们既可以通过Dispatcher.CurrentDispatcher获得当前线程Dispatcher对象,也可以通过访问Dispatcher.CurrentDispatcher

    68910

    dotnet 读 WPF 源代码笔记 创建 SolidColorBrush 性能没有想象那么差

    但在通过阅读 WPF 源代码,发现其实 SolidColorBrush 创建性能其实是特别好,因此请不要担心创建了太多纯色画刷类 在 WPF ,画刷 Brush 有很多实现,本文内容是纯色画刷实现...在 WPF 纯色画刷是继承 Brush 类,这个类自己定义只有一个字段 _duceResource 和 Color 一个属性,而 Color 属性是一个依赖属性。...如上文可以了解到在 SolidColorBrush 颜色属性是依赖属性,假定没有传入构造参数,那么将会使用依赖属性默认值,也就是说此实例仅仅只使用到字段 _duceResource 内存。...从内存层面,在 SolidColorBrush 类本身,不算继承类情况下,只有一个字段和一个依赖属性,占用内存量不会比 Color 结构体多多少。...欢迎转载、使用、重新发布,但务必保留文章署名林德熙(包含链接: https://blog.lindexi.com ),不得用于商业目的,基于本文修改作品务必相同许可发布。

    72350

    WPF架构学习总结

    DispatcherObject(异步)     命令空间:System.Threading。     WPF Dispatcher使用User32消息机制来实现线程调用。...主要原因是互可操作性,因为现在很多系统都是需要STA,如IE、OLE2.0、剪贴板等。     通过Dispatcher,我们可以实现线程通信。...继承自DispatcherObejct类,都获取了一个所在线程Dispatcher引用,这样,任何使用这个类对象线程,都可以使用它Dispatcher来发送“消息”。...一般情况下,我们使用这个类意图主要是异步线程调用DispatcherObjectDispather来让DispatcherObject创建线程做一些特定事情,如设置界面上某个值。...在User32和GDI,系统是通过一种盒子方式来进行绘制:每一个成员都被放在一个指定区域里面进行绘制,然后再叠加再一起。这样生成图象每一个象素,其实都只属于唯一一个成员。

    1.7K80

    .NET中有多少种定时器

    它要求用户代码有可用UI消息泵,定时任务须在UI线程上运行,或者线程通过Invoke或者BeginInvoke封送(marshal)到UI线程上运行。...,它是基于Dispatcher对象(并不是基于UI线程)。...Dispatcher为特定线程维护工作项(操作)优先级队列,在线程上创建Dispatcher对象时,它成为唯一可以关联该线程Dispatcher对象,WPFDispatcherObject只能被与之关联...Dispatcher对象访问,也就是非UI线程无法直接访问UI元素(WPFUI元素都是派生自 DispatcherObject) 此外,DispatcherTimer不像System.Windows.Forms.Timer...在创建定时器对象时必须指定回调方法,并且后续不能修改,同时也可以指定定时器回调开始执行时间以及时间间隔。定时器创建后可以通过Change方法修改回调开始执行时间以及时间间隔。

    23510

    .NET 中有多少种定时器

    它要求用户代码有可用UI消息泵,定时任务须在UI线程上运行,或者线程通过Invoke或者BeginInvoke封送(marshal)到UI线程上运行。...,它是基于Dispatcher对象(并不是基于UI线程)。...Dispatcher为特定线程维护工作项(操作)优先级队列,在线程上创建Dispatcher对象时,它成为唯一可以关联该线程Dispatcher对象,WPFDispatcherObject只能被与之关联...Dispatcher对象访问,也就是非UI线程无法直接访问UI元素(WPFUI元素都是派生自DispatcherObject) 此外,DispatcherTimer不像System.Windows.Forms.Timer...在创建定时器对象时必须指定回调方法,并且后续不能修改,同时也可以指定定时器回调开始执行时间以及时间间隔。定时器创建后可以通过Change方法修改回调开始执行时间以及时间间隔。

    24211

    学习WPF——WPF布局——了解布局容器

    DispatcherObject WPF应用程序使用单线程亲和模型(STA:Single-Thread Affinity),这意味着整个用户界面都为单个线程拥有,同时也意味着从另一个线程与用户界面元素交互是不安全...WPF属性实现机制和Winform程序有很大差异,Winform控件属性很多是通过继承机制得来,在你认为超过90%用户界面控件属性通常留其初始值时,为每一个属性存储一个字段将是对内存巨大浪费...DependencyObject(依赖属性)解决了仅仅存储改变了属性问题。默认值在依赖属性只存储一次。这只是依赖项属性一个好处,还有其他好处我们以后再聊。...Z轴顺序 我们知道在Canvas布局容器,如果位置重叠,后设置元素会盖住先设置元素, 如果想打破这种规定,那么可以使用ZIndex属性: ?...修改记录 2014-12-26:编写前两部分内容 2014-12-29:修改第二节内容,增加最后两节内容 2014-12-30:完成剩余内容 2015-01-05:修改了几个文字 参考资料

    2.3K50

    WPF Application.Current.Dispatcher ,为什么 Current 可能为 null

    在 WPF 程序,可能会存在 Application.Current.Dispatcher.Xxx 这样代码让一部分逻辑回到主 UI 线程。...WPF Application.Current.Dispatcher Dispatcher 属性一定不会为 null WPF Application.Current.Dispatcher ...在 Application 实例构造函数: _appInstance 赋值是线程安全,这意味着多个 Application 实例构造不会因为线程安全问题导致 _appInstance 字段状态不正确...,请参见我另一篇博客: WPF Application.Current.Dispatcher Dispatcher 属性一定不会为 null - walterlv ---- 参考资料 Application.cs...欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://blog.walterlv.com ),不得用于商业目的,基于本文修改作品务必相同许可发布。

    55030

    WPF消息机制(二)- WPF内部5个窗口之隐藏消息窗口

    在上一篇,我们频繁提及“线程”,“Dispatcher”其实,运行WPF应用程序所在线程就是WPF所谓UI线程,在Application.Run之后,调用Dispatcher.Run时会检查当前线程是否已经存在了一个...Dispatcher对象,如果没有就构造一个,在这里,一个线程对应一个Dispatcher。...因此,WPF对象在获取this.Dispatcher属性时,不同对象都是同一个Dispatcher实例。...隐藏消息窗口 创建时机:在Application构造函数调用基类DispatcherObject构造函数时候,会创建一个Dispatcher对象,在Dispatcher私有构造函数当中。...WPF也是通过BeginInvoke来解决,而WpfBeginInvoke是在Dispatcher上面暴露了,因为整个消息系统都是Dispatcher在协调。

    1.9K50

    出让执行权:Task.Yield, Dispatcher.Yield

    更新于 2018-02-19 22:31 一个耗时任务,可以通过 Task.Yield 或者 Dispatcher.Yield 来中断以便分割成多个小任务片段执行。...我之前介绍过 Invoke 和 InvokeAsync 可以解决,将后续耗时任务分割成一个个小片段低于用户输入和渲染优先级执行。..._dispatcher.BeginInvoke(_priority, d, state); } 既然是 Normal 优先级,那么在 UI 线程效果自然不如 Dispatcher.Yield。...但是,Task.Yield 适用于任何线程,因为 SynchronizationContext 本身是与 Dispatcher 无关,适用于任何线程。...欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://walterlv.com ),不得用于商业目的,基于本文修改作品务必相同许可发布

    87210

    【愚公系列】2023年11月 WPF控件专题 2023秋招WPF高频面试题

    提供平滑图形效果,例如阴影和颜色渐变。使用可相同控件使用共享样式,提供相同主题、皮肤和设计。变换对象,包括形状、控件和视频。可以创建和动画 3D 图形。...Dispatcher: 一个抽象基类,用于绑定到一个线程类。与Windows窗体类似,WPF也要求仅从创建线程调用方法和属性。...为此,每个需要线程关联元素最终都是从 DispatcherObject 类派生。 此类提供名为 Dispatcher 属性,该属性返回与 WPF 元素关联 Dispatcher 对象。...依赖属性优点如下:减少内存占用当 UI 控件 90% 以上属性通常保持其初始值时,为每个属性存储一个字段是一种巨大消耗。 依赖属性通过仅在实例存储修改属性来解决这些问题。...依赖属性优点如下:减少内存占用当 UI 控件 90% 以上属性通常保持其初始值时,为每个属性存储一个字段是一种巨大消耗。 依赖属性通过仅在实例存储修改属性来解决这些问题。

    49422

    VisualStudio 通过 EditorBrowsable 隐藏不开放属性或方法

    在开发,总是会有一些方法不期望让大家直接使用到,就可以通过 EditorBrowsable 特性让智能提示不显示这个属性或方法 假设我开发了这样一个类 public class Foo...Console.WriteLine("林德熙是逗比"); } } 现在 VisualStudio 智能提示就不能够提示这个方法了,但是 Resharper 依然可以提示,只有通过...在于自己写了一些不想让小伙伴用属性或方法时候 在 WPF 底层就在 DispatcherObject CheckAccess 判断调用线程是否是创建线程方法标记了这个特性,只有了解 WPF 依赖属性小伙伴才能使用这个方法...,同时有更好阅读体验。...欢迎转载、使用、重新发布,但务必保留文章署名林德熙(包含链接: https://lindexi.gitee.io ),不得用于商业目的,基于本文修改作品务必相同许可发布。

    85430

    VisualStudio 通过 EditorBrowsable 隐藏不开放属性或方法

    在开发,总是会有一些方法不期望让大家直接使用到,就可以通过 EditorBrowsable 特性让智能提示不显示这个属性或方法 假设我开发了这样一个类 public class Foo...Console.WriteLine("林德熙是逗比"); } } 现在 VisualStudio 智能提示就不能够提示这个方法了,但是 Resharper 依然可以提示,只有通过...ReSharper > Options > Environment > IntelliSense > Completion Appearance 设置去掉 EditorBrowsable 值才能不显示...在于自己写了一些不想让小伙伴用属性或方法时候 在 WPF 底层就在 DispatcherObject CheckAccess 判断调用线程是否是创建线程方法标记了这个特性,只有了解 WPF 依赖属性小伙伴才能使用这个方法...当然这个做法没有接口隐藏方法做好,只是使用起来方便 Resharper 配置 EditorBrowsableAttribute Class

    46520
    领券