c#异步调用一个带返回值的方法并获取返回值

委托可以进行同步调用和异步调用。
委托的同步调用用Invoke方法实现。同步调用也可以叫阻塞调用,它将阻塞当前线程,然后执行调用,调用完毕后再继续向下进行。同步调用会阻塞线程,如果是要调用一项繁重的工作(如大量IO操作),可能会让程序停顿很长时间,造成糟糕的用户体验,这时候异步调用就很有必要了。
委托的异步调用通过BeginInvoke和EndInvoke来实现。异步调用不阻塞线程,而是把调用塞到线程池中,程序主线程或UI线程可以继续执行。

首先,声明委托并创建委托实例,委托要和方法有相同的参数和返回类型
public delegate int AsyncDelegate(int a);
private AsyncDelegate mydlgt = new AsyncDelegate(MyFunc);

了解一下BeginInvoke的原型
IAsyncResult AsyncDelegate.BeginInvoke(int a,AsyncCallback asyncCallback,object @object)
BeginInvoke方法触发你的异步方法,它和你想要执行的异步方法有相同的参数。另外还有两个可选参数,第一个是AsyncCallback委托是异步完成的回调方法。第二个是用户自定义对象,该对象将传递到回调方法中。
//开启异步执行方法MyFunc
IAsyncResult result = mydlgt.BeginInvoke(asyncCallback,null);

//异步调用的方法
private int MyFunc(int a)
{
}
AsyncCallback asyncCallback = new AsyncCallback(AsyncCallbackFunc);

//回调方法
public void AsyncCallbackFunc(IAsyncResult ar)
{
		int r = mydlgt.EndInvoke(ar);//在回调方法中结束异步,并获取返回值
}

也可以在主线程中结束异步,当主线程运行到EndInvoke时,如果这时异步调用没有结束(这种情况很可能出现),这时为了等待调用结果,线程依旧会被阻塞。
mydlgt.EndInvoke(result);

因此,用回调函数,当调用结束时会自动调用回调函数,解决了为等待调用结果,而让线程依旧被阻塞的局面。

C#中,可以使用Thread类来创建多个线程,并通过调用方法来启动这些线程。如果要在多线程中调用参数有返回值方法,可以使用委托和异步回调来实现。下面是一个简单的示例代码,演示如何创建和启动多个线程来调用同一个参数有返回值方法: ```csharp using System; using System.Threading; class Program { static void Main(string[] args) { // 创建3个线程 Thread t1 = new Thread(new ParameterizedThreadStart(MyMethod)); Thread t2 = new Thread(new ParameterizedThreadStart(MyMethod)); Thread t3 = new Thread(new ParameterizedThreadStart(MyMethod)); // 启动这些线程 t1.Start(1); t2.Start(2); t3.Start(3); // 等待这些线程结束 t1.Join(); t2.Join(); t3.Join(); Console.WriteLine("所有线程已结束"); } static void MyMethod(object param) { int num = (int)param; // 这里是你要执行的方法 Console.WriteLine("线程 {0} 正在执行 MyMethod,参数为 {1}", Thread.CurrentThread.ManagedThreadId, num); // 模拟方法执行 Thread.Sleep(1000); // 返回结果 int result = num * 2; // 调用回调函数返回结果 AsyncCallback callback = new AsyncCallback(MyCallback); callback.BeginInvoke(result, null, null); } static void MyCallback(IAsyncResult result) { int num = (int)result.AsyncState; Console.WriteLine("线程 {0} 的 MyMethod 方法返回了结果 {1}", Thread.CurrentThread.ManagedThreadId, num); } } ``` 在这个示例中,我们创建了3个线程,并通过调用Thread.Start()方法来启动它们。这些线程都会调用同一个方法MyMethod(),并传入一个整数参数。在MyMethod()方法中,我们模拟了方法的执行过程,并最终返回了一个整数结果。为了返回结果,我们使用了异步回调的方式,将结果传递给MyCallback()方法进行处理。在MyCallback()方法中,我们输出了方法执行的结果。 需要注意的是,多线程编程需要注意线程安全性,以免出现竞态条件等问题。在实际开发中,需要根据具体情况来选择适合的多线程编程模型和技术。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值