C# 创建线程的简单方式:异步委托 .
定义一个委托调用的方法:TakesAWhile
- //定义委托要引用的方法
- private static int TakesAWhile(int data, int ms)
- {
- Console.WriteLine("开始...");
- //当前线程(委托线程)阻塞ms毫秒
- Thread.Sleep(ms);
- Console.WriteLine("完成!");
- return ++data;
- }
//定义委托要引用的方法
private static int TakesAWhile(int data, int ms)
{
Console.WriteLine("开始...");
//当前线程(委托线程)阻塞ms毫秒
Thread.Sleep(ms);
Console.WriteLine("完成!");
return ++data;
}
定义一个委托:
- public delegate int TakesAWhileDelegate(int data, int ms);
public delegate int TakesAWhileDelegate(int data, int ms);
以下是异步调用委托的3种方式:
1.投票
- /* 异步调用委托之:投票,检查委托是否完成任务 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);
- /*
/* 异步调用委托之:投票,检查委托是否完成任务 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.等待句柄
- /* 异步调用委托之:等待句柄 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 */
/* 异步调用委托之:等待句柄 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.异步回调
- //定义委托调用完毕后的回调方法
- 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);
- }
//定义委托调用完毕后的回调方法
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);
}
- /* 异步调用委托之:异步回调 star */
- TakesAWhileDelegate d1 = TakesAWhile;
- d1.BeginInvoke(1, 3000, TakesAWhileCommpleted, d1);
- for (int i = 0; i < 100; i++)
- {
- Console.WriteLine(".");
- Thread.Sleep(500);
- }
- /* 异步调用委托之:异步回调 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# 创建线程的简单方式:异步委托 .的更多相关文章
- java创建线程的多种方式
java创建线程的四种方式 1.继承 Thread 类 通过继承 Thread 类,并重写它的 run 方法,我们就可以创建一个线程. 首先定义一个类来继承 Thread 类,重写 run 方法. 然 ...
- pthread创建线程的简单演示
使用pthread创建子线程的简单步骤 导入头文件 #import <pthread.h> 指定新线程标识符 使用pthread创建线程的函数 根据result = 0 与否判断子线程 ...
- 创建线程的一般方式和匿名内部类方式对比——实现runnable接口,重新run方法
启动:使用静态代理设计模式 优点:可同时实现继承,避免单继承局限性 一般方式: Programer.java /** * 真实角色 * * @author :liuqi * @date :2018-0 ...
- 创建线程的一般方式和匿名内部类方式对比——继承thread类,重写run()方法
第一种:继承thread类,重写run()方法 一般方式:Demo01.java /** * 创建线程的第一种方式:继承thread类,重写run()方法 * * @author :liuqi * @ ...
- Java中创建线程主要有三种方式
一.继承Thread类创建线程类 (1)定义Thread类的子类,并重写该类的run方法,该run方法的方法体就代表了线程要完成的任务.因此把run()方法称为执行体. (2)创建Thread子类的实 ...
- Java创建线程四种方式
1.继承Thread类 public class MyThread extends Thread { public MyThread() { } public void run() { for(int ...
- 多线程-创建线程第二种方式-实现Runnable接口-细节和好处
1 package multithread2; 2 3 /* 4 * 创建线程的第一种方法:继承Thread类 5 * 6 * 创建线程的第二种方式:实现Runnable接口 7 * 8 * 1,定义 ...
- Java并发编程原理与实战五:创建线程的多种方式
一.继承Thread类 public class Demo1 extends Thread { public Demo1(String name) { super(name); } @Override ...
- java多线程 -- 创建线程的第三者方式 实现Callable接口
Java 5.0 在 java.util.concurrent 提供了一个新的创建执行线程的方式:Callable 接口Callable 接口类似于 Runnable,两者都是为那些其实例可能被另一个 ...
随机推荐
- E2202 Required package 'VclJPG' not found
xe8 [dcc32 Fatal Error] RaizeComponentsVcl_Design.dpk(40): E2202 Required package 'VclJPG' not found ...
- ubuntu设置服务开机启动
在Ubuntu下用sysv-rc-conf命令,它是chkconfig的替代命令,而使用方法与chkconfig基本相同. 安装: sudo apt-get install sysv-rc-conf ...
- MVC中过虑特殊字符检测
[ValidateInput(false)] [HttpPost] public ActionResult Modify(Models.BlogArticle model) { //...... } ...
- C++11多态函数对象包装器
[C++11多态函数对象包装器] 针对函数对象的多态包装器(又称多态函数对象包装器)在语义和语法上和函数指针相似,但不像函数指针那么狭隘.只要能被调用,且其参数能与包装器兼容的都能以多态函数对象包装器 ...
- Android之旅 笔记总结(一)
一.Android入门 1. Android操作系统的体系结构分为4层,由上而下依次是应用程序.应用程序框架.核心类库(包括Android运行时环境)和Linux内核. 2. ...
- Unity3d:如何让程序在失去焦点时,继续运行,而不是暂停呢?
问题描述如题.解决方案: <ignore_js_op> <ignore_js_op>
- Proxy代理(AOP实现原理)
AOP基于动态代理实现:返回代理对象 java.lang.reflect 包Proxy 类,构造代理类.newProxyInstance() 就是创建代理对象的方法. Proxy.newProxyIn ...
- JS:中文GB2312编码
今天开发遇到了个问题,有点纳闷.... 在ajax的时候要传递一个中文值,不管我在js中是否使用了encodeURI.encodeURIComponent编码,但是在后台request获取的值是始终是 ...
- php 将字符串中的连续多个空格转换为一个空格
转载自:http://www.phpernote.com/php-function/633.html /** * 多个连续空格只保留一个 * * @param string $string 待转换的字 ...
- Xcode快捷键整理
下面是Xcode比较常用的快捷键,特别是红色标注的,很常用.用熟了开发编辑代码的的时候就很方便,希望对大家有用~1. 文件CMD + N: 新文件CMD + SHIFT + N: 新项目CMD + O ...