【转】.Net下多线程编程[9]——异步编程
阅读目录
一:同步处理
二:异步处理
三:异步委托
四:通过委托同步调用方法
五:通过委托异步调用方法
一:同步处理
一个同步操作会阻塞整个当前的进程,直到这个操作完成才能执行下一段代码
二:异步处理
不会阻塞启动操作的调用线程,调用程序必须通过轮流检测,或者等待完成信号来发现调用的完成
三:异步委托
. 异步委托通过以异步方式调用同步方法的能力,在《同步调用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();
}