推荐一种异步线程执行过程中更新进度的方法
<p>在实际应用中,对于耗时较长或者耗费性能的操作,为了避免UI卡顿,通常采用后台异步线程的方式进行处理,但用户需要知道当前操作的执行进度(如当前进度百分比),以及一些更详细的过程信息(如共分5步,当前是正在执行第几步)等内容。实现此功能有很多种方法,今天介绍一种通过.NET自带的IProgress接口实现进度上报的操作方法,谨供学习分享使用,如有不足之处,还请指正。</p><p><img src="https://img2024.cnblogs.com/blog/1068941/202511/1068941-20251109220637318-1940105948.png"></p>
<p> </p>
<h1>IProgress概述</h1>
<p> </p>
<p>IProgress接口是微软在.NET Framework4.5及之后的版本中提供的一种用于异步方法中进度上报的方法接口及实现。IProgress<T>及它的实现类Progress<T>是泛型实现,它接收基础数据类型或自定义的引用类型。Progress<T>初始化对象时,接收一个Action<T> 的handler,当调用接口的Report(T value)方法时,就会执行Action<T>对应的handler委托方法进行更新进度。</p>
<p>涉及知识点如下:</p>
<ol>
<li>Report<T value> 用于向外报告一个进度更新。</li>
<li>Progress(Action<T> handler) 实现类的构造函数,参数为更新进度的委托。</li>
</ol>
<p> </p>
<h1>示例代码</h1>
<p> </p>
<p>在本示例中,创建Execute方法,模拟后台耗时较长的任务,并在执行过程中通过IProgress接口的Report方法上报执行进度。如下所示:</p>
<pre class="language-csharp highlighter-hljs"><code>private async Task Execute(IProgress<TaskReport> progress)
{
for (int i = 0; i < 100; i++)
{
//do somthing
await Task.Delay(200);
progress.Report(new TaskReport()
{
Percent=i,
Msg=$"当前是第{i}个步骤,进行中"
});
}
progress.Report(new TaskReport()
{
Percent=100,
Msg="完成"
});
}</code></pre>
<p>接着创建IProgress的实例对象,并传入当Report方法调用时,需要执行的委托RefreshUI,用于刷新页面的进度,如下所示:</p>
<pre class="language-csharp highlighter-hljs"><code>private async void btnExceute_Click(object sender, EventArgs e)
{
IProgress<TaskReport> progress = new Progress<TaskReport>(RefreshUI);
await Execute(progress);
}</code></pre>
<p>其中RefreshUI方法,主要用于为UI页面上的进度条和Label赋值,如下所示:</p>
<pre class="language-csharp highlighter-hljs"><code>private void RefreshUI(TaskReport taskReport)
{
this.pb1.Value = taskReport.Percent;
this.lblMsg.Text = taskReport.Msg;
}</code></pre>
<p> </p>
<h1>演示效果</h1>
<p> </p>
<p>运行实例,点击执行按钮如下所示:</p>
<p><img src="https://img2024.cnblogs.com/blog/1068941/202511/1068941-20251109214652959-102619980.gif"></p>
<p>以上就是《推荐一种异步线程执行过程中更新进度的方法》的全部内容,旨在抛砖引玉,一起学习,共同进步!</p>
</div>
<div id="MySignature" role="contentinfo">
<div id="AllanboltSignature">
<p style="border-top: #e0e0e0 1px dashed; border-right: #e0e0e0 1px dashed; border-bottom: #e0e0e0 1px dashed; border-left: #e0e0e0 1px dashed; padding-top: 10px; padding-right: 10px; padding-bottom: 10px; padding-left: 30px; font-family: 微软雅黑; font-size: 12px" id="PSignature">
<br>
<img alt="" src="https://images.cnblogs.com/cnblogs_com/hsiang/1154298/o_115f1cd8.jpg" width="80px" height="80px">
作者:老码识途
<br>
出处:http://www.cnblogs.com/hsiang/
<br>
本文版权归作者和博客园共有,写文不易,支持原创,欢迎转载【点赞】,转载请保留此段声明,且在文章页面明显位置给出原文连接,谢谢。
<br>关注个人公众号,定时同步更新技术及职场文章
<br><br>
</p>
</div><br><br>
来源:https://www.cnblogs.com/hsiang/p/19204635
頁:
[1]