WinForm解决UI假死
运行WinForm程序时,如果后台执行比较费时的操作,前天UI就会假死卡住,很影响使用感受,这里我们简单的解决一下这个问题
其本质就是将业务逻辑放到异步线程中执行,但是这样的话在异步线程中操作控件就会报错,因此需要再回到控件所在的主线程中操作控件
2023-10-19精简版示例代码
private void BtnTest1_Click(object sender, EventArgs e) { Task.Run(() => { //业务逻辑需要异步执行,否则会阻塞主线程 for (int i = 0; i < 100; i++) { //当前是异步线程,不能直接为UI线程的控件赋值,需要在控件所在的线程上通过委托进行赋值 LblMsg.Invoke((Action)(() => { LblMsg.Text = $"任务执行{i}%"; })); Thread.Sleep(1000); //模拟执行复杂的任务 } }); }
之前的旧示例
using System; using System.Collections.Concurrent; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Diagnostics; using System.Drawing; using System.IO; using System.Linq; using System.Text; using System.Threading; using System.Threading.Tasks; using System.Windows.Forms; namespace WinForm { public partial class MainForm : Form { public MainForm() { InitializeComponent(); } /// <summary> /// 后台要执行的操作 /// </summary> private void AAA() { for (int i = 0; i < 999999999; i++) //模拟耗时的操作 { if (i % 9999999 == 0) //每隔9999999次循环ui更新下百分比 { this.label1.Invoke((Action<int>)delegate(int a) //在控件对象所在的线程上执行委托 { this.label1.Text = a.ToString() + "%"; }, i / 9999999); } } } private void button1_Click(object sender, EventArgs e) { ((Action)AAA).BeginInvoke(null, null); //调用委托的异步执行方法,回调函数为空 } } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~