C# 委托随笔
委托是指向函数的函数指针,而且是类型安全的。使用委托可以执行的一项有用操作是实现回调。回调是传入函数的方法,在函数结束执行时调用该方法。例如,有一个函数执行一个非常耗时的操作,在调用该函数时,同时也传入了一个回调方法(利用委托实现),从而在函数执行完成时,调用该回调方法,通知用户计算的结果。下面是一个用委托实现回调的示例:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace DelegateDemo
{
class Program
{
delegate void callBackdelegate(string strMessage);
static void Main(string[] args)
{
callBackdelegate callback = ResultCallback;
AddNumber(100, 200, callback);
Console.ReadLine();
}
static void AddNumber(int num1, int num2,callBackdelegate callBack)
{
int result = num1 + num2;
callBack("Result is : "+result.ToString());
}
static void ResultCallback(string strMessage)
{
Console.WriteLine(strMessage);
}
}
}
上面的示例只是同步回调,也就是说在执行函数AddNumber时(假设该函数执行很长时间),UI线程是会阻塞的,至到该函数执行完毕。这就给用户带来了不好的体验。其实我们在日常的软件开发中,用的最多的就是异步回调技术,该技术是指 在执行函数AddNumber时,UI线程不会阻塞。下面我们就用异步回调重写上面的示例:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Runtime.Remoting.Messaging;
namespace DelegateDemo
{
class Program
{
//声明一个委托,签名与AddNumber函数相同
delegate int MethodDelegate(int num1, int num2);
static void Main(string[] args)
{
MethodDelegate del = AddNumber;
AsyncCallback callback = new AsyncCallback(ResultCallBack);
IAsyncResult result = del.BeginInvoke(100, 200, callback, null);
Console.WriteLine("UI线程继续执行。。。。");
Console.ReadLine();
}
static int AddNumber(int num1, int num2)
{
//用线程模拟一个耗时的操作
System.Threading.Thread.Sleep(5000);
return num1 + num2;
}
static void ResultCallBack(IAsyncResult ar)
{
//将ar强制转换为 AsyncResult 类型 该类型需引入命名空间System.Runtime.Remoting.Messaging
MethodDelegate del = (MethodDelegate)((AsyncResult)ar).AsyncDelegate;
int result = del.EndInvoke(ar);
Console.WriteLine("The result is :" + result.ToString());
}
}
}
以上代码实现了对函数AddNumber的异步回调。

浙公网安备 33010602011771号