C#--无法将lambda表达式转换为类型‘Delegate’,原因是它不是委托类型

报错如下:

 

主要是为了在子线程中更新UI线程

 对于Control.Invoke()来说,任何的代理类型都是可接受的,也就是说ThreadStart和MethodInvoker都是可以接受的类型。这样编译器反而不知道应该用哪个代理去匹配匿名函数了,导致了编译错误的发生。
知道了原因,问题就很容易解决了。我们只需要加上MethodInvoker这个wrapper就能使用匿名函数了。

this.label7.Invoke(new MethodInvoker(delegate { this.label7.Text = msg.strMsg; }));

或者用lamada表达式:
this.label7.Invoke(new MethodInvoker(() => this.label7.Text = msg.strMsg));

 

// 以下为委托的几种写法

             1、 this.Invoke( (MethodInvoker)(()=> { …方法体…}));

             2、 this.Invoke( (MethodInvoker) delegate{…方法体…});

             3、this.Invoke( new MethodInvoker (()=> { …方法体…}));

             4、 this.Invoke( new MethodInvoker (delegate{…方法体…}));

posted @   包子789654  阅读(4884)  评论(2编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示