博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ASP.NET温故而知新学习系列之ASP.NET多线程编程—异步编程(九)
阅读量:6197 次
发布时间:2019-06-21

本文共 1802 字,大约阅读时间需要 6 分钟。

  阅读目录

  一:同步处理

  二:异步处理

  三:异步委托

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

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

  一:同步处理

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

  

  二:异步处理

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

  

  三:异步委托

   . 异步委托通过以异步方式调用同步方法的能力,在《同步调用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();

   }

  

 

 

转载地址:http://kqjca.baihongyu.com/

你可能感兴趣的文章
Linux第十五周
查看>>
顺序栈的初始化 入栈 出栈以及 打印栈的信息
查看>>
算法调整后关于外链的思考
查看>>
将windows系统装到USB存储设备
查看>>
分享matlab程序之——滤波器篇(高通,低通)
查看>>
DELL R710错误代码汇总
查看>>
勒索病毒、敲诈者病毒、wallet比特币病毒加密数据后的应急处理
查看>>
在 Ruby 中执行 Shell 命令的 6 种方法
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
使yum保留下载的rpm包
查看>>
关于ntfs权限的问题
查看>>
华为vlan聚合(超级vlan)配置实例
查看>>
我的友情链接
查看>>
Mysql 服务器主从 主主配置
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
Citrix结合CKEY实现双因子认证
查看>>
TDDL动态数据源开源-基本说明
查看>>
Jenkins+Ant可持续集成Jmeter脚本
查看>>