c# winform异步不卡界面的实现方法

编辑: admin 分类: c#语言 发布时间: 2022-03-12 来源:互联网

快速阅读

如何在winform程序中,让界面不再卡死。 关于委托和AsyncCallback的使用。

界面卡死的原因是因为耗时任务的计算占用了主线程,导致主界面没有办法进行其它操作,比如拖动。造成界面卡死的现象。我们只需要把耗时任务放在子线程中执行就可以了。

子线程的计算结果 要更新到界面中,怎么更新呢,因为不能操作主线程 ,所以要用委托来实现 。

我们来看个例子。

场景

界面上一个按钮加一人richbox , 点击以后获得当前所在年份

代码实现

定义一个委托实现子线程更新主线程

public delegate void UpdateText(string message);

public void UpdateTextMehod(string message)
{
 richTextBox1.Text += message+"\r\n";
 richTextBox1.ScrollToCaret();
}

按钮的点击事件

func委托:表示模拟一个耗时的操作(2s),然后返回一个结果 。

Asynccallback:表示在相应异步操作完成时调用的方法。在这个方法中,获取异步执行的结果。

​ 要获取异步执行的结果,要调用func.EncInvoke(IAsyncResult)

实例化更新主线程 的委托UpdateText,然后异步调用,在func委托的计算结果 赋值给界面

func异步调用 ,把该异步的的回调方法当做参数传入。

 Func<int> func = new Func<int>(() =>
      {
        Thread.Sleep(2000);
        return DateTime.Now.Year;
      });
      AsyncCallback callback=new AsyncCallback((x) =>
      {
        var result=func.EndInvoke(x);
        UpdateText ut = new UpdateText(UpdateTextMehod);
        this.BeginInvoke(ut, result.ToString());

      });

      func.BeginInvoke(callback, "object vlaue");

注意

最后一句代码,可以写成这样,但是会卡死,

var res =func.BeginInvoke(null,null);
var result1 = func.EndInvoke(res).ToString();
richTextBox1.Text += result1.ToString();

所以异步方法的执行结果要放在回调函数中,这样就不会卡死主界面。

切记。

总结

以上就是这篇文【本文由http://www.1234xp.com/xgzq.html首发,转载请保留出处,谢谢】章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对海外IDC网的支持。