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); //调用委托的异步执行方法,回调函数为空 
        }
    }
}
复制代码

 

posted @   WmW  阅读(3251)  评论(1编辑  收藏  举报
编辑推荐:
· 从 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的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示