ASP.NET温故而知新学习系列之ASP.NET多线程编程—异步编程(九)

  阅读目录

  一:同步处理

  二:异步处理

  三:异步委托

  四:通过委托同步调用方法

  五:通过委托异步调用方法

  一:同步处理

   一个同步操作会阻塞整个当前的进程,直到这个操作完成才能执行下一段代码

  

  二:异步处理

   不会阻塞启动操作的调用线程,调用程序必须通过轮流检测,或者等待完成信号来发现调用的完成

  

  三:异步委托

   . 异步委托通过以异步方式调用同步方法的能力,在《同步调用WebService和异步调用WebService》一文中,里面也讲过了,同样一个Web服务,只是因为调用的方式不同,就成了同步调用和异步调用了,同步就是直接调用

   . 当同步调用一个委托时,调用方法直接为当前线程的目标方法,这里就是指GetNameFirst()方法,如果编译器支持异步委托,则它将生成BeginInvoke()方法和EndInvoke()方法

   . 只要是任何函数在我们的编译器中,除了直接调用之外,还有一个异步调用,也就是BeginInvoke()和EndInvoke(),BeginInvoke()返回结果是判断执行是否完成,EndInvoke()返回调用结果

  四:通过委托同步调用方法

  class User
      {
          //要调用的动态方法
          public string GetNameFirst()
          {

       Thread.Sleep(30000);
              return "从小就犯困";
          }

          //要调用的静态方法
          public static string GetNameSecond()
          {

              return "从小就犯困";
          }
     }

  //委托声明(函数签名)
      delegate string MyMethodDelegate(); 
      static void Main(string[] args)

  {

    User user = new User();
            //方式一:同步调用方法,声明一个委托变量mydelegate,且绑定到动态方法GetNameFirst
            MyMethodDelegate my_delegate = new MyMethodDelegate(user.GetNameFirst);
            string strResult = my_delegate();
            Console.WriteLine(strResult);
            Console.ReadKey();

  }

  因为我们让当前线程休眠的时间是30秒,所以我们要等到30秒后才能输出“从小就犯困”  

  

  

  五:通过委托异步调用方法

  using System.Runtime.Remoting.Messaging;

  delegate string MyMethodDelegate(); 
      static void Main(string[] args)

  {

    //方式二:异步调用方法,声明一个委托变量mydelegate,且绑定到动态方法GetNameSecond
        MyMethodDelegate my_delegate = new MyMethodDelegate(User.GetNameSecond);
        AsyncResult async_result;//此类封闭异步委托异步调用的结果,通过AsyncResult得到结果
        //开始调用
        async_result = (AsyncResult)my_delegate.BeginInvoke(null, null);
        //判断线程是否执行完成
        while (!async_result.IsCompleted)
        {
                Console.WriteLine("正在异步执行方法GetNameSecond()......");
         }
         Console.WriteLine("方法GetNameSecond()执行完成");
         //等待委托调用的方法的完成
         string strResult = my_delegate.EndInvoke(async_result);
         Console.WriteLine(strResult);
         Console.ReadKey();

   }

  

原文地址:https://www.cnblogs.com/menglin2010/p/2420021.html