WCF 第二章 契约 异步访问服务操作

好的设计会降低用户必须等待一个任务结束然后初始化另一个任务之前的情况。例如,当一个e-mail客户端正在下载新邮件,你仍然可以读或者删除已 经下载下来的邮件。或者当一个浏览器正在下载一个网页上引用的图片时,你仍然可以拖动网页或者跳转到任何地方。在客户端程序中的多任务形式是通过异步设计 模式来完成的。

在WCF中,请求-回复服务操作导致当服务操作在执行时客户端被阻塞。更深一层,由svcutil.exe生成的代理代码使用阻塞来调用服务通信信 道栈。这使得客户端应用程序在服务调用过程中被阻塞。如果服务需要十分钟完成,客户端引用程序将会在整个调用过程中冻结来等待回复。

幸运的是,你可以在.NET Framework中使用异步编程模式来在客户端引入异步行为。这种模式在.NET 1.0 中引入,使任何同步方法都可以被异步调用。它是通过引入IAsyncResult类而且通过创建两个方法,BeginOperationName和 EndOperationName来实现异步调用的。客户端首先调用BeginOperationName然后可以继续在当前线程执行代码知道一步操作执 行一个不同的线程。对每一个调用BeginOperationName的调用来说,客户端接下来调用EndOperationName来获取操作结果。当 异步操作被调用时而且可以从BeginOperationName调用存储状态信息时,客户端传输一个委托给BeginOperationName客户端 传送一个委托给BeginOperationName.

你可以直接使用添加服务引用来生成异步调用方法。者通过点击添加服务引用对话框的高级选项然后选择生成异步操作选项。服务引用设置对话框在图片 2.4中显示。对应的,除了同步方法,Svcutil 实例和/async 选项使用这个模式来为每个服务操作创建一个Begin<Operation>和End<Operation>方法。

WCF 第二章 契约 异步访问服务操作

图片2.5显示了通过SvcUtil生成的客户端并在.NET Framework中使用异步模式。注意服务端并不知道客户端使用异步编程模式;服务端的契约仅仅确认请求-回复通信而客户端不用服务端参与完成异步模式。

WCF 第二章 契约 异步访问服务操作

列表2.4说明了使用IAsyncResult和BeginGetPrice和EndGetPrice来维护服务操作状态。 BeginGetPrice除了定义为服务操作输入的字符串还需要两个参数。第一个参数,AsyncResult.第二个参数可以是任何用来在初始化和异 步回调间传输状态的对象。当服务操作完成时它以AsyncResult.AsyncState被传输给AsyncCallback.传输初始化服务通信的 代理类是有用的,因为这样EndGetPrice就可以在AsyncCallback中被调用来获取服务操作反馈。静态变量,c,被用来阻止客户在服务完 成时推出,Interlocked类用来确保在多处理器机器上可以有线程安全性。

列表2.4 使用.NET异步模式完成请求-回复客户端

using System;
using System.ServiceModel;
using System.Threading;
 
namespace AW.EssentialWCF.Samples
{
    class Program
    {
        static int c = 0;
        static void Main(string[] args)
        {
            StockServiceClient proxy = new StockServiceClient();
            IAsyncResult arGetPrice;
            for (int i = 0; i < 10; i++)
            {
                arGetPrice = proxy.BeginGetPrice("msft", GetPriceCallback, proxy);
                InterLocker.Increment(ref c);
            }
            while (c > 0)
            {
                Thread.Sleep(1000);
                Console.WriteLine("Waiting... Calls outstanding:{0}", c);
            }
            proxy.Close();
            Console.WriteLine("Done!");
        }
 
        //Asynchronous callbacks for displaying results.
        static void GetPriceCallback(IAsyncResult ar)
        {
            double d = ((StockServiceClient)ar.AsyncState).EndGetPrice(ar);
            Interlocked.Decrement(ref c);
        }
        
    }
}

=================

转载自

作者: DanielWise
出处: http://www.cnblogs.com/danielWise/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
 

你可能感兴趣的:(WCF)