C#实现异步编程的方法

C#实现异步编程的方法,第1张

概述最近在我参与的几个.Net项目中都有用到异步编程,作为一名.Net小白,很有必要好好地学习一下C#异步编程。

最近在我参与的几个.Net项目中都有用到异步编程,作为一名.Net小白,很有必要好好地学习一下C#异步编程。

什么是异步

异步指的就是不用阻塞当前线程来等待任务的完成,而是将任务扔到线程池中去执行,当前线程可以继续向下执行,直至其它线程将任务完成,并回调通知当前线程。整个任务从开始到结束都是异步完成的,不会阻塞当前线程。因此,异步很重要的一点就是,不会阻塞当前线程。

实现异步编程

在C#语言中,主要是通过委托来实现异步编程的,在委托类型中定义了两个方法BeginInvoke()和EndInvoke()。

/// <summary>/// 开始执行异步 *** 作./// </summary>/// <param name="param">委托方法的参数</param>/// <param name="callback"></param>/// <param name="object"></param>/// <returns></returns>IAsyncResult BeginInvoke(int param,AsyncCallback callback,Object @object);/// <summary>/// 结束执行异步 *** 作,并且返回异步 *** 作结果./// </summary>/// <param name="result"></param>/// <returns>委托方法的返回类型</returns>string EndInvoke(IAsyncResult result);

下面就通过一段代码来具体实现异步编程

/// <summary>/// 定义一个委托类型/// </summary>public delegate string Del();/// <summary>/// 任务类/// </summary>public class TaskClass{  public static string SleepTask()  {    Console.Writeline("异步线程(ThreadID = {0})开始执行睡眠任务,睡眠3s.\n",Thread.CurrentThread.ManagedThreadID);    Thread.Sleep(3000);    Console.Writeline("异步线程(ThreadID = {0})苏醒,睡眠任务执行结束.\n",Thread.CurrentThread.ManagedThreadID);    return "异步线程执行成功.\n";  }}  /// <summary>/// 异步编程实现类(主线程不会阻塞)/// </summary>public class AsynCallbackClass{  public static string result;  public static voID Main(string[] args)  {    Console.Writeline("主线程(ThreadID = {0})开始执行.\n",Thread.CurrentThread.ManagedThreadID);    Del del = new Del(TaskClass.SleepTask);    Console.Writeline("主线程(ThreadID = {0})调用BeginInvoke()方法执行异步任务.\n",Thread.CurrentThread.ManagedThreadID);    //开始执行异步 *** 作,TaskClass.SleepTask无参数,Callback为定义的回调方法.    del.BeginInvoke(Callback,null);    Console.Writeline("主线程(ThreadID = {0})继续执行.\n",Thread.CurrentThread.ManagedThreadID);    Thread.Sleep(5000);    //输出异步任务返回的结果    Console.Writeline(result);    Console.Writeline("主线程(ThreadID = {0})执行结束.\n",Thread.CurrentThread.ManagedThreadID);  }  /// <summary>  /// 回调方法  /// </summary>  /// <param name="ar"></param>  public static voID Callback(IAsyncResult ar)  {    AsyncResult asyncResult = ar as AsyncResult;    if (asyncResult == null) { return; }    Del del = asyncResult.AsyncDelegate as Del;    if (del == null) { return; }    Console.Writeline("回调方法中调用EndInvoke()方法,获取异步任务结果.\n",Thread.CurrentThread.ManagedThreadID);        //结束执行异步 *** 作,并返回异步任务结果.    result = del.EndInvoke(ar);  }}

运行结果:

从运行结果中,我们可以发现主线程在调用了BeginInvoke()方法后,没有阻塞,而是继续向下执行,而且任务也确实由一个新的线程来执行,任务执行结束后,调用回调方法,在回调方法中调用EndInvoke()方法来获取任务执行结果。

总结

1. 在异步编程中,当前线程是不会被阻塞的。

2. C#的委托机制可以很方便地实现异步编程。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

总结

以上是内存溢出为你收集整理的C#实现异步编程的方法全部内容,希望文章能够帮你解决C#实现异步编程的方法所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/1255526.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-07
下一篇2022-06-07

发表评论

登录后才能评论

评论列表(0条)

    保存