以前学的ASP.NET,调用的都是同步方法,同步方法的好处就是,一步一步走,完成这步才会走下一步。然而,WCF使用的都是异步方法,调用之后不管有没有获得结果就直接往下走,最可恶的是异步函数都是Void类型,得不到返回结果,虽然有Completed的事件处理,但是还是感觉比较束缚,无法与前端交互。
这里就跟大家分享一种传入回调函数的方法,把前台的方法写好,传到后台,让异步方法调用完成时执行。废话不多说了,开始写代码:
首先,要先建一个带网站的sliverlight项目,这里就不细说了,在网站中添加一个Silverlight-enabled Wcf Service,随便写一个方法,就用自动生成的Dowork方法吧,下面是代码:
using System; using System.Linq; using System.Runtime.Serialization; using System.ServiceModel; using System.ServiceModel.Activation; namespace Silverlight.Web { [ServiceContract(Namespace = "")] [SilverlightFaultBehavior] [AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)] public class Service { [OperationContract] public string DoWork() { // Add your operation implementation here return "OK,this WCF Server is running..."; } // Add more operations here and mark them with [OperationContract] } }
方法很简单,就是返回一个字符串,下面在Sliverlight中添加服务引用,引用刚才新建的服务,然后写一个测试方法,代码如下:
public void Test(Action<string> callback) { ServiceReference1.ServiceClient sc = new ServiceReference1.ServiceClient(); sc.DoWorkAsync(callback); sc.DoWorkCompleted += new EventHandler<ServiceReference1.DoWorkCompletedEventArgs>(sc_DoWorkCompleted); }
这个方法调用了WCF服务的方法,并绑定了Completed的事件,这里需要注意的是,我们的WCF中的DoWork方法并没有任何参数,这里却传入了一个Action<T>委托,没错,这个就是回调函数,DoWorkAsync() 系统默认有个重载方法DoWorkAsync(object userState),有个参数为object userState,所以可以对这个参数赋值,把我们的回调函数传进去,下面是回调函数的调用:
void sc_DoWorkCompleted(object sender, ServiceReference1.DoWorkCompletedEventArgs e) { CallBackMethod<string>(e,() => {return e.Result;}); } public void CallBackMethod<T>(AsyncCompletedEventArgs e, Func<T> GetT) { if (e.UserState != null) { (e.UserState as Action<T>)(GetT()); } }
这里是最精简的写法,当然可以自己扩展,添加错误处理等,使其功能变的更加强大,但这里主要就是使用了userState参数,传入了回调函数,从而执行的。
(e.UserState as Action<T>)(GetT());就是这句,把userState参数参数当作一个Action<T>委托执行。
接下来看看怎么使用吧,代码如下:
private void button1_Click(object sender, RoutedEventArgs e) { Test(result => { if (result != null) { result += " Haha,so eazy!"; MessageBox.Show(result); } }); }
这里回调函数,我们传入lambda表达式,至此,回调函数就完成了。
在开发中,自己可以根据需要完善方法。