当前位置: 首页 > news >正文

C# BackgroundWorker的使用

C# 中的 BackgroundWorker 类是 .NET Framework 提供的一个组件,用于在后台线程上异步执行长时间运行的操作,同时保持与用户界面(UI)的交互,如更新进度信息或处理取消请求。这使得可以轻松地在不冻结UI的情况下执行耗时的任务。

以下是如何在 C# 中使用 BackgroundWorker 的基本步骤:

  1. 初始化 BackgroundWorker: 在窗体加载或者其他合适的地方创建一个 BackgroundWorker 实例,并设置其属性。

    private BackgroundWorker backgroundWorker = new BackgroundWorker();// 在构造函数或Form_Load事件中初始化
    public Form1()
    {InitializeComponent();InitializeBackgroundWorker();
    }private void InitializeBackgroundWorker()
    {// 允许报告进度backgroundWorker.WorkerReportsProgress = true;// 允许在后台任务执行过程中取消操作backgroundWorker.WorkerSupportsCancellation = true;// 为DoWork、ProgressChanged和RunWorkerCompleted事件添加事件处理器backgroundWorker.DoWork += bgWorker_DoWork;backgroundWorker.ProgressChanged += bgWorker_ProgressChanged;backgroundWorker.RunWorkerCompleted += bgWorker_WorkerCompleted;
    }
  2. 定义 DoWork 事件处理程序: 这是在后台线程上实际执行工作的位置。通过调用 ReportProgress() 方法可以发送进度信息到主线程。

    private void bgWorker_DoWork(object sender, DoWorkEventArgs e)
    {BackgroundWorker worker = sender as BackgroundWorker;for (int i = 1; i <= 100; i++){if (worker.CancellationPending) // 检查是否收到取消请求{e.Cancel = true;break;}else{// 执行耗时操作var result = PerformSomeLongRunningOperation(i);// 如果允许报告进度,则报告当前进度worker.ReportProgress(i, result);// 可能需要在此处模拟延迟,例如 Thread.Sleep(100);}}
    }
  3. 定义 ProgressChanged 事件处理程序: 当 ReportProgress() 被调用时,这个事件会触发,用来更新 UI 上的进度条或其他进度指示器。

    private void bgWorker_ProgressChanged(object sender, ProgressChangedEventArgs e)
    {int progressPercentage = e.ProgressPercentage;string message = e.UserState as string; // 如果传递了其他数据// 更新进度条控件progressBar.Value = progressPercentage;// 或者显示消息labelProgress.Text = $"已完成 {progressPercentage}%";
    }
  4. 定义 RunWorkerCompleted 事件处理程序: 当后台任务完成(成功、失败或被取消)时,此事件将触发,可以在这里进行清理工作或者通知用户操作已完成。

    private void bgWorker_WorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
    {if (e.Cancelled){MessageBox.Show("操作已取消");}else if (e.Error != null){MessageBox.Show($"后台工作遇到错误: {e.Error.Message}");}else{MessageBox.Show("后台工作已完成!");// 此处可以获取后台任务的结果(如果有),例如:var result = e.Result;}// 恢复之前禁用的界面元素buttonStart.Enabled = true;buttonCancel.Enabled = false;
    }
  5. 启动 BackgroundWorker: 在按钮点击事件或其他触发点调用 RunWorkerAsync() 来开始执行后台任务。

    private void buttonStart_Click(object sender, EventArgs e)
    {// 禁止再次点击直到后台任务完成buttonStart.Enabled = false;buttonCancel.Enabled = true;// 启动后台任务并可选择性传递参数backgroundWorker.RunWorkerAsync();
    }
  6. 取消 BackgroundWorker: 如果支持取消,在取消按钮的点击事件中调用 CancelAsync() 方法来请求取消后台任务。

    private void buttonCancel_Click(object sender, EventArgs e)
    {backgroundWorker.CancelAsync();
    }

以上就是一个典型的 BackgroundWorker 使用示例,注意实际应用中根据具体需求调整代码。

 

虽然 .NET Framework 和 .NET Core/.NET 5 及更高版本依然支持 BackgroundWorker,但在现代开发中更倾向于使用 Task 和 async/await 关键字来实现异步编程,或者使用 IProgress<T> 接口结合 async 方法来报告进度。

请注意,使用BackgroundWorker时,要确保任务是可中断的,因为它是在一个单独的线程中执行的。如果任务需要连续执行,可能需要特殊的处理。

 

http://www.lryc.cn/news/297131.html

相关文章:

  • (简单有案例)前端实现主题切换、动态换肤的两种简单方式
  • wyh的迷宫
  • AWS云用户创建
  • 微信小程序(三十七)选项点击高亮效果
  • 通过Demo学WPF—数据绑定(二)
  • 数据湖的整体思路
  • 51单片机 跑马灯
  • 迎新年年终总结
  • 一台服务器可以支持多少TCP连接
  • svg基础(六)滤镜-图像,光照效果(漫反射,镜面反射),组合
  • 电脑数据误删如何恢复?9 个Windows 数据恢复方案
  • 【doghead】uv_loop_t的创建及线程执行
  • 云计算运营模式介绍
  • 物资捐赠管理系统
  • YOLOv8改进 | 检测头篇 | 独创RFAHead检测头超分辨率重构检测头(适用Pose、分割、目标检测)
  • 私有化部署一个吃豆人小游戏
  • 社区店经营管理新思路:提升业绩的秘诀
  • 统一数据格式返回,统一异常处理
  • arm 平台安装snort3
  • 【Ubuntu 20.04/22.04 LTS】最新 esp-matter SDK 软件编译环境搭建步骤
  • 【C语言】案例:输出n位水仙花数
  • 代码随想录算法训练营第四十六天(动态规划篇)|01背包(滚动数组方法)
  • 【QT+QGIS跨平台编译】之三十:【NetCDF+Qt跨平台编译】(一套代码、一套框架,跨平台编译)
  • 从0开始图形学(光栅化)
  • B站弹幕分析系统
  • 戴上HUAWEI WATCH GT 4,解锁龙年新玩法
  • 鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之StepperItem组件
  • 2024-02-08 Unity 编辑器开发之编辑器拓展1 —— 自定义菜单栏与窗口
  • Intellij IDEA各种调试+开发中常见bug
  • 文件上传-Webshell