定义一个委托调用的方法:TakesAWhile

  1. //定义委托要引用的方法
  2. private static int TakesAWhile(int data, int ms)
  3. {
  4. Console.WriteLine("开始...");
  5. //当前线程(委托线程)阻塞ms毫秒
  6. Thread.Sleep(ms);
  7. Console.WriteLine("完成!");
  8. return ++data;
  9. }

//定义委托要引用的方法
private static int TakesAWhile(int data, int ms)
{
Console.WriteLine("开始...");

//当前线程(委托线程)阻塞ms毫秒
Thread.Sleep(ms);

Console.WriteLine("完成!");

return ++data;
}

定义一个委托:

  1. public delegate int TakesAWhileDelegate(int data, int ms);

public delegate int TakesAWhileDelegate(int data, int ms);

以下是异步调用委托的3种方式:

1.投票

  1. /* 异步调用委托之:投票,检查委托是否完成任务 star */
  2. TakesAWhileDelegate d1 = TakesAWhile;
  3. IAsyncResult ar = d1.BeginInvoke(1, 3000, null, null);
  4. //检查委托是否完成
  5. while (!ar.IsCompleted)
  6. {
  7. Console.WriteLine(".");
  8. //当前线程(主线程)阻塞500毫秒,因此最后会打出6个"."
  9. Thread.Sleep(500);
  10. }
  11. //EndInvoke()方法会一直等待,直到委托完成为止,用于接收结果
  12. int result = d1.EndInvoke(ar);
  13. Console.WriteLine("结果:" + result);
  14. /*

/* 异步调用委托之:投票,检查委托是否完成任务 star */
TakesAWhileDelegate d1 = TakesAWhile;

IAsyncResult ar = d1.BeginInvoke(1, 3000, null, null);

//检查委托是否完成
while (!ar.IsCompleted)
{
Console.WriteLine(".");

//当前线程(主线程)阻塞500毫秒,因此最后会打出6个"."
Thread.Sleep(500);
}

//EndInvoke()方法会一直等待,直到委托完成为止,用于接收结果
int result = d1.EndInvoke(ar);

Console.WriteLine("结果:" + result);
/*

2.等待句柄

  1. /* 异步调用委托之:等待句柄 star */
  2. TakesAWhileDelegate d1 = TakesAWhile;
  3. IAsyncResult ar = d1.BeginInvoke(1, 3000, null, null);
  4. while (true)
  5. {
  6. Console.WriteLine(".");
  7. //AsyncWaitHandle访问等待句柄
  8. //WaitOne()第一个参数为一超时时间,即要等待的最大时间,超时返回false,继续while循环
  9. if (ar.AsyncWaitHandle.WaitOne(500, false))
  10. {
  11. Console.WriteLine("可获得结果啦Baby!");
  12. break;
  13. }
  14. }
  15. //EndInvoke()方法会一直等待,直到委托完成为止,用于接收结果
  16. int result = d1.EndInvoke(ar);
  17. Console.WriteLine("结果:" + result);
  18. /* 异步调用委托之:等待句柄 end */

/* 异步调用委托之:等待句柄 star */
TakesAWhileDelegate d1 = TakesAWhile;

IAsyncResult ar = d1.BeginInvoke(1, 3000, null, null);

while (true)
{
Console.WriteLine(".");

//AsyncWaitHandle访问等待句柄
//WaitOne()第一个参数为一超时时间,即要等待的最大时间,超时返回false,继续while循环
if (ar.AsyncWaitHandle.WaitOne(500, false))
{
Console.WriteLine("可获得结果啦Baby!");

break;
}
}

//EndInvoke()方法会一直等待,直到委托完成为止,用于接收结果
int result = d1.EndInvoke(ar);

Console.WriteLine("结果:" + result);
/* 异步调用委托之:等待句柄 end */

3.异步回调

  1. //定义委托调用完毕后的回调方法
  2. private static void TakesAWhileCommpleted(IAsyncResult ar)
  3. {
  4. if (ar == null)
  5. {
  6. throw new ArgumentException("ar");
  7. }
  8. TakesAWhileDelegate d1 = ar.AsyncState as TakesAWhileDelegate;
  9. int result = d1.EndInvoke(ar);
  10. Console.WriteLine("结果:" + result);
  11. }

//定义委托调用完毕后的回调方法
private static void TakesAWhileCommpleted(IAsyncResult ar)
{
if (ar == null)
{
throw new ArgumentException("ar");
}

TakesAWhileDelegate d1 = ar.AsyncState as TakesAWhileDelegate;

int result = d1.EndInvoke(ar);
Console.WriteLine("结果:" + result);
}

  1. /* 异步调用委托之:异步回调 star */
  2. TakesAWhileDelegate d1 = TakesAWhile;
  3. d1.BeginInvoke(1, 3000, TakesAWhileCommpleted, d1);
  4. for (int i = 0; i < 100; i++)
  5. {
  6. Console.WriteLine(".");
  7. Thread.Sleep(500);
  8. }
  9. /* 异步调用委托之:异步回调 end */

/* 异步调用委托之:异步回调 star */
TakesAWhileDelegate d1 = TakesAWhile;

d1.BeginInvoke(1, 3000, TakesAWhileCommpleted, d1);

for (int i = 0; i < 100; i++)
{
Console.WriteLine(".");

Thread.Sleep(500);
}
/* 异步调用委托之:异步回调 end */

注:异步模式,不仅用于委托,异步模式在.NET Framework的各个地方都能见!

C# 创建线程的简单方式:异步委托 .的更多相关文章

  1. java创建线程的多种方式

    java创建线程的四种方式 1.继承 Thread 类 通过继承 Thread 类,并重写它的 run 方法,我们就可以创建一个线程. 首先定义一个类来继承 Thread 类,重写 run 方法. 然 ...

  2. pthread创建线程的简单演示

      使用pthread创建子线程的简单步骤 导入头文件 #import <pthread.h> 指定新线程标识符 使用pthread创建线程的函数 根据result = 0 与否判断子线程 ...

  3. 创建线程的一般方式和匿名内部类方式对比——实现runnable接口,重新run方法

    启动:使用静态代理设计模式 优点:可同时实现继承,避免单继承局限性 一般方式: Programer.java /** * 真实角色 * * @author :liuqi * @date :2018-0 ...

  4. 创建线程的一般方式和匿名内部类方式对比——继承thread类,重写run()方法

    第一种:继承thread类,重写run()方法 一般方式:Demo01.java /** * 创建线程的第一种方式:继承thread类,重写run()方法 * * @author :liuqi * @ ...

  5. Java中创建线程主要有三种方式

    一.继承Thread类创建线程类 (1)定义Thread类的子类,并重写该类的run方法,该run方法的方法体就代表了线程要完成的任务.因此把run()方法称为执行体. (2)创建Thread子类的实 ...

  6. Java创建线程四种方式

    1.继承Thread类 public class MyThread extends Thread { public MyThread() { } public void run() { for(int ...

  7. 多线程-创建线程第二种方式-实现Runnable接口-细节和好处

    1 package multithread2; 2 3 /* 4 * 创建线程的第一种方法:继承Thread类 5 * 6 * 创建线程的第二种方式:实现Runnable接口 7 * 8 * 1,定义 ...

  8. Java并发编程原理与实战五:创建线程的多种方式

    一.继承Thread类 public class Demo1 extends Thread { public Demo1(String name) { super(name); } @Override ...

  9. java多线程 -- 创建线程的第三者方式 实现Callable接口

    Java 5.0 在 java.util.concurrent 提供了一个新的创建执行线程的方式:Callable 接口Callable 接口类似于 Runnable,两者都是为那些其实例可能被另一个 ...

随机推荐

  1. E2202 Required package 'VclJPG' not found

    xe8 [dcc32 Fatal Error] RaizeComponentsVcl_Design.dpk(40): E2202 Required package 'VclJPG' not found ...

  2. ubuntu设置服务开机启动

    在Ubuntu下用sysv-rc-conf命令,它是chkconfig的替代命令,而使用方法与chkconfig基本相同. 安装: sudo apt-get install sysv-rc-conf ...

  3. MVC中过虑特殊字符检测

    [ValidateInput(false)] [HttpPost] public ActionResult Modify(Models.BlogArticle model) { //...... } ...

  4. C++11多态函数对象包装器

    [C++11多态函数对象包装器] 针对函数对象的多态包装器(又称多态函数对象包装器)在语义和语法上和函数指针相似,但不像函数指针那么狭隘.只要能被调用,且其参数能与包装器兼容的都能以多态函数对象包装器 ...

  5. Android之旅 笔记总结(一)

    一.Android入门 1.          Android操作系统的体系结构分为4层,由上而下依次是应用程序.应用程序框架.核心类库(包括Android运行时环境)和Linux内核. 2.     ...

  6. Unity3d:如何让程序在失去焦点时,继续运行,而不是暂停呢?

    问题描述如题.解决方案: <ignore_js_op> <ignore_js_op>

  7. Proxy代理(AOP实现原理)

    AOP基于动态代理实现:返回代理对象 java.lang.reflect 包Proxy 类,构造代理类.newProxyInstance() 就是创建代理对象的方法. Proxy.newProxyIn ...

  8. JS:中文GB2312编码

    今天开发遇到了个问题,有点纳闷.... 在ajax的时候要传递一个中文值,不管我在js中是否使用了encodeURI.encodeURIComponent编码,但是在后台request获取的值是始终是 ...

  9. php 将字符串中的连续多个空格转换为一个空格

    转载自:http://www.phpernote.com/php-function/633.html /** * 多个连续空格只保留一个 * * @param string $string 待转换的字 ...

  10. Xcode快捷键整理

    下面是Xcode比较常用的快捷键,特别是红色标注的,很常用.用熟了开发编辑代码的的时候就很方便,希望对大家有用~1. 文件CMD + N: 新文件CMD + SHIFT + N: 新项目CMD + O ...