网站首页 > java教程 正文
第一种方法: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 异步调用实现方法汇总
{
/// <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);
}
}
}
第三种方法:轮询。也是属于“等待”类。
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());
}
}
}
需要注意的地方,代码中都有注明了,程序运行结果如下:
通过EndInvoke方法得到同步函数的返回值。上面的同步方法返回值为void,我们给个例子:
using System.Diagnostics;
using System.Threading;
using System.Windows;
namespace TestDelegateWrapper
{
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
}
private void ButtonBase_OnClick(object sender, RoutedEventArgs e)
{
WrapperSyncMethodAsync("ABC");
Trace.WriteLine("Main thread continue...");
}
private delegate string SyncMethod1Delegate(string str);
private void WrapperSyncMethodAsync(string str)
{
SyncMethod1Delegate syncMethod1Delegate = SyncMethod1;
syncMethod1Delegate.BeginInvoke(str, x =>
{
var result= syncMethod1Delegate.EndInvoke(x);
// using the result to do something
Trace.WriteLine(result);
}, null);
}
private string SyncMethod1(string str)
{
Thread.Sleep(2000);
return str;
}
}
}
输出如下:
Main thread continue...
ABC
以上就是四种实现异步调用函数的四种方法,说的很清楚了,就写这么多~
reference:.NET Framework Delegates: Understanding Asynchronous Delegates
DebugLZQ后续之作:从C#5.0说起:再次总结C#异步调用方法发展史
大家都不是牛人,多多学习,多多交流【请点击下面的“绿色通道”---“关注DebugLZQ”,共同交流进步~】
分类: Design Patterns, Multithreading Asynchronous, .NET Miscellaneous
好文要顶 关注我 收藏该文
猜你喜欢
- 2025-05-22 @Async引发线上服务内存溢出如何处理
- 2025-05-22 RabbitMQ与Java集成的典型用例:从消息传递到任务调度的全面探索
- 2025-05-22 JAVA面试|Redis原理及应用场景
- 2025-05-22 并发编程:CompletableFuture异步编程没有那么难
- 2025-05-22 06.整合rabbitmq异步处理
- 2025-05-22 同步 vs 异步性能差100倍!SpringBoot3 高吞吐接口实现终极方案
- 2025-05-22 Java高并发处理的艺术:让程序飞起来!
- 2025-05-22 HttpClient的异步调用,你造吗?
- 2025-05-22 @Async:一个异步方法调用另一个异步方法难道不是异步吗?
- 2025-05-22 Serverless革命:Java函数计算性能突破
你 发表评论:
欢迎- 05-23Java线程池:核心参数与最佳实践
- 05-23深入理解 Java 的线程池原理
- 05-23面试突击34:如何使用线程池执行定时任务?
- 05-23Java线程池核心参数调优指南:掌控并发世界的钥匙
- 05-23Java线程池:优雅管理并发任务的艺术
- 05-23一篇文章快速搞懂Java中常用的四种线程池
- 05-23Java线程池工作原理深度解读:从创建到任务执行的全过程
- 05-23一文看懂:Java线程池任务拒绝机制解析
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)