最近很忙,既要外出找工作又要兼顾老板公司的项目。今天在公司,忙里偷闲,总结一下.NET中的异步调用函数的实现方法,DebugLZQ在写这篇博文之前自己先动手写了本文的所有示例代码,开写之前是做过功课的,用代码说话方有说服力。
本文的内容旨在用最简洁的代码来把异步调用的方法说清楚,园子里的高手老鸟可以绕行,不喜勿喷,非诚勿扰~
lz的前一篇文章简单的说了下异步,主要是从理解上来讲;这篇文章主要写具体的实现方法。实现异步编程有4种方法可供选择,这4种访求实际上也对应着4种异步调用的模式,分为“等待”和“回调”两大类。四种方法,我在代码中都进行了详细的注释,这里不罗嗦了,直接用代码说明吧
第一种方法:BeginEnvoke EndEnvoke方法,属于“等待”类。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
namespace 异步调用实现方法汇总
{
/// <summary>
/// 异步调用方法总结:
/// 1.BeginEnvoke EndEnvoke
/// 当使用BeginInvoke异步调用方法时,如果方法未执行完,EndInvoke方法就会一直阻塞,直到被调用的方法执行完毕
/// </summary>
class Program
{
public delegate void PrintDelegate(string s);
static void Main(string[] args)
{
PrintDelegate printDelegate = Print;
Console.WriteLine("主线程");
IAsyncResult result= printDelegate.BeginInvoke("Hello World.", null, null);
Console.WriteLine("主线程继续执行...");
//当使用BeginInvoke异步调用方法时,如果方法未执行完,EndInvoke方法就会一直阻塞,直到被调用的方法执行完毕
printDelegate.EndInvoke(result);
Console.WriteLine("Press any key to continue...");
Console.ReadKey(true);
}
public static void Print(string s)
{
Console.WriteLine("异步线程开始执行:"+s);
Thread.Sleep(5000);
}
}
}
需要注意的地方,代码中都有注明了,程序运行结果如下:
第二种方法:WaitOne。同样属于“等待”类。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
namespace 异步调用实现方法汇总2
{
/// <summary>
/// 异步调用方法总结:
/// 2.WaitOne
/// 可以看到,与EndInvoke类似,只是用WaitOne函数代码了EndInvoke而已。
/// </summary>
class Program
{
public delegate void PrintDelegate(string s);
static void Main(string[] args)
{
PrintDelegate printDelegate = Print;
Console.WriteLine("主线程");
IAsyncResult result = printDelegate.BeginInvoke("Hello World.", null, null);
Console.WriteLine("主线程继续执行...");
result.AsyncWaitHandle.WaitOne(-1, false);
Console.WriteLine("Press any key to continue...");
Console.ReadKey(true);
}
public static void Print(string s)
{
Console.WriteLine("异步线程开始执行:" + s);
Thread.Sleep(5000);
}
}
}
需要注意的地方,代码中都有注明了,程序运行结果如下:
第三种方法:轮询。也是属于“等待”类。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
namespace 异步调用实现方法汇总3
{
/// <summary>
/// 异步调用方法总结:
/// 3.轮询
/// 之前提到的两种方法,只能等下异步方法执行完毕,
/// 在完毕之前没有任何提示信息,整个程序就像没有响应一样,用户体验不好,
/// 可以通过检查IasyncResult类型的IsCompleted属性来检查异步调用是否完成,
/// 如果没有完成,则可以适时地显示一些提示信息
/// </summary>
class Program
{
public delegate void PrintDelegate(string s);
static void Main(string[] args)
{
PrintDelegate printDelegate = Print;
Console.WriteLine("主线程:"+Thread.CurrentThread.ManagedThreadId );
IAsyncResult result = printDelegate.BeginInvoke("Hello world.", null, null);
Console.WriteLine("主线程:" + Thread.CurrentThread.ManagedThreadId + ",继续执行...");
while (!result.IsCompleted)
{
Console.WriteLine(".");
Thread.Sleep(500);
}
Console.WriteLine("主线程:" + Thread.CurrentThread.ManagedThreadId + " Press any key to continue...");
Console.ReadKey(true);
}
public static void Print(string s)
{
Console.WriteLine("当前线程:" + Thread.CurrentThread.ManagedThreadId + s);
Thread.Sleep(5000);
}
}
}
需要注意的地方,代码中都有注明了,程序运行结果如下:
第四种方法:回调。当然属于“回调”类。推荐!!!!
之前三种方法者在等待异步方法执行完毕后才能拿到执行的结果,期间主线程均处于等待状态。回调和它们最大的区别是,在调用BeginInvoke时只要提供了回调方法,那么主线程就不必要再等待异步线程工作完毕,异步线程在工作结束后会主动调用我们提供的回调方法,并在回调方法中做相应的处理。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
namespace 异步调用实现方法汇总4
{
/// <summary>
/// 异步调用方法总结:
/// 4.回调
/// 之前三种方法者在等待异步方法执行完毕后才能拿到执行的结果,期间主线程均处于等待状态。
/// 回调和它们最大的区别是,在调用BeginInvoke时只要提供了回调方法,那么主线程就不必要再等待异步线程工作完毕,
/// 异步线程在工作结束后会主动调用我们提供的回调方法,并在回调方法中做相应的处理,例如显示异步调用的结果。
/// </summary>
class Program
{
public delegate void PrintDelegate(string s);
static void Main(string[] args)
{
PrintDelegate printDelegate = Print;
Console.WriteLine("主线程.");
printDelegate.BeginInvoke("Hello world.", PrintComeplete, printDelegate);
Console.WriteLine("主线程继续执行...");
Console.WriteLine("Press any key to continue...");
Console.ReadKey(true);
}
public static void Print(string s)
{
Console.WriteLine("当前线程:"+s);
Thread.Sleep(5000);
}
//回调方法要求
//1.返回类型为void
//2.只有一个参数IAsyncResult
public static void PrintComeplete(IAsyncResult result)
{
(result.AsyncState as PrintDelegate).EndInvoke(result);
Console.WriteLine("当前线程结束." + result.AsyncState.ToString());
}
}
}
需要注意的地方,代码中都有注明了,程序运行结果如下:
以上就是四种实现异步调用函数的四种方法,说的很清楚了,就写这么多~
分享到:
相关推荐
- **异步编程**:异步编程能够提高应用程序的响应性和效率,特别是在处理耗时的IO操作或网络请求时尤为重要。 - **并行编程**:通过并行编程可以充分利用多核处理器的能力,加快程序执行速度,常见的库如TPL(Task ...
1. **ASP.NET Web Forms或ASP.NET MVC**:两种技术都可以用于构建此系统,Web Forms适合快速开发,MVC则更强调分离关注点。 2. **C#编程语言**:ASP.NET主要使用的编程语言,用于编写服务器端代码。 3. **SQL ...
例如,理解内存管理机制,避免不必要的对象创建,合理使用缓存,以及利用多线程和异步编程来提高程序响应速度。此外,单元测试和持续集成也是最佳实践,它们能确保代码质量,减少错误,加速开发流程。 .NET平台还...
通过阅读和分析源码,开发者可以掌握实际开发中的技巧和最佳实践,例如使用ASP.NET的MVC模式进行项目结构规划,使用ADO.NET进行数据库交互,以及运用AJAX实现页面异步更新等。 总结来说,这个资源为学习和研究ASP...
- **异步编程**:虽然在C# 2010中还不支持async/await关键字,但本书可能提到了相关的异步编程模式和技巧。 - **动态对象**:介绍如何使用dynamic关键字来创建动态对象,这些对象可以在运行时动态地获取属性和方法...
在.NET中,Socket类提供了丰富的异步方法,如`BeginConnect`、`BeginSend`、`BeginReceive`等,它们都遵循异步编程模型,即回调函数模式。在处理网络I/O时,可以避免线程被阻塞,提高系统资源的利用率。 总结一下,...
最近收集的VB.Net-C#多线程Thread-代理委托delegate编程。文章列表: c#.net多线程同步.txt C#WebBrowser页面与WinForm交互技巧一.txt ...微软.Net开发中的多线程编程总结.txt 线程中的参数传递.txt
总结,第六章和第七章的深入学习将使开发者对.NET平台和C#编程有更全面的理解,掌握这些知识后,无论是开发企业级应用还是构建高性能的桌面应用,都能游刃有余。通过实践和不断地学习,你可以充分利用.NET平台的潜力...
ASP.NET提供了一种模型驱动的开发方式,支持多种编程语言如C#、VB.NET等。它包括Web Forms、MVC(Model-View-Controller)和Web Pages等多种开发模式,满足不同类型的项目需求。Web Forms模式提供了一种基于事件驱动...
本文将详细总结ASP.NET的常用功能,帮助开发者更好地理解和应用这一技术。 1. **页面生命周期** ASP.NET页面生命周期包括初始化、加载、验证、呈现和卸载等阶段。开发者在这些阶段可以进行数据绑定、事件处理和...
C#是一种类型安全、面向对象的编程语言,它支持许多现代编程概念,如泛型、lambda表达式、异步编程等。在".NET高级应用-Test3.zip"中,可能包含对这些特性的深入实践案例,通过学习这些案例,你可以更好地掌握C#的...
6. **C#语言**:ASP.NET的后端编程主要使用C#语言,C#是面向对象的、现代的编程语言,支持特性如lambda表达式、LINQ、异步编程等。熟悉C#的基本语法、类库以及高级特性是ASP.NET开发的基础。 以上知识点只是ASP.NET...
总结来说,《VB.NET网络编程指南》是一个全面的学习资源,涵盖了从Web基础到ASP.NET高级特性的广泛内容。通过阅读这份图文并茂的教程,你将能够熟练地运用VB.NET进行网络编程,开发出功能丰富的Web应用。无论是新手...
**C# 7.1** 是一种面向对象的编程语言,它在C# 7的基础上增加了许多新特性,这些特性使得开发人员能够更高效地编写代码。C# 7.1 的一些关键特性包括: - **局部函数**:允许开发者在方法内部定义其他函数,这样可以...
总结来说,这个Asp.net同异步线程实例展示了如何利用异步编程提高Web应用的性能,以及如何结合客户对象进行更灵活的页面设计。它强调了异步编程在解决性能瓶颈和提升用户体验上的重要性,同时也提醒开发者在处理并发...