成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

WCF異步調(diào)用實際應(yīng)用技巧分析

開發(fā) 開發(fā)工具
WCF異步調(diào)用的合理使用,可以幫助我們在實際開發(fā)中獲得很多幫助。在這里我們將會通過一段示例來詳細講解有關(guān)實現(xiàn)方法。

WCF已經(jīng)推出就受到了廣大開發(fā)人員的關(guān)注。作為一個.NET Framework 3.5的重要組成部分,它的應(yīng)用可以幫助我們創(chuàng)建一個安全性高的可依賴性框架,為開發(fā)人員帶來極大的方便。首先,為我們就先來了解一下WCF異步調(diào)用的相關(guān)介紹。

WCF與Web Service不同的是,當我們定義了服務(wù)契約的操作時,不管是通過ChannelFactory創(chuàng)建服務(wù)代理對象,還是通過SvcUtil的默認方式生成服務(wù)代理對象,客戶端在調(diào)用這些代理對象時,都無法直接實現(xiàn)WCF異步調(diào)用方式的調(diào)用。例如,對于如下的服務(wù)操作定義:

  1. [OperationContract]  
  2. Stream TransferDocument(Document document); 

在調(diào)用代理對象的方法時,我們無法找到對應(yīng)于TransferDocument()操作的BeginTransferDocument()和EndTransferDocument()異步方法。#t#

這樣的設(shè)計使得我們無法通過編程方式異步地調(diào)用服務(wù)的操作,除非我們在定義服務(wù)接口時,直接加入相關(guān)操作的異步方法。然而,這又直接導致了服務(wù)的設(shè)計與方法調(diào)用方式之間的耦合。一個好的框架設(shè)計要素在于,不管客戶端的調(diào)用方式(同步或者異步),服務(wù)的設(shè)計與實現(xiàn)應(yīng)該是一致的。對于服務(wù)的設(shè)計者而言,在設(shè)計之初,就不應(yīng)該去考慮服務(wù)的調(diào)用者調(diào)用的方式。換言之,服務(wù)操作究竟是否采用WCF異步調(diào)用方式,應(yīng)該由客戶端的調(diào)用者決定。因此,所有與異步調(diào)用相關(guān)的內(nèi)容應(yīng)該只與客戶端相關(guān)。WCF遵循了這一規(guī)則。

在我編寫的應(yīng)用程序中,會暴露一個傳送文檔文件的服務(wù)操作。我并不知道也并不關(guān)心調(diào)用該操作的客戶端是否采用異步方式。因此,如上所述的服務(wù)操作定義是完全正確的。

那么,客戶端究竟應(yīng)該如何執(zhí)行異步調(diào)用呢?如果采用編程方式獲得服務(wù)代理對象,這一問題會變得比較糟糕。因為我將服務(wù)契約的定義單獨形成了一個程序集,并在客戶端直接引用了它。然而,在這樣的服務(wù)契約程序集中,是沒有包含異步方法的定義的。因此,我需要修改在客戶端的服務(wù)定義,增加操作的異步方法。這無疑為服務(wù)契約的重用帶來障礙。至少,我們需要在客戶端維持一份具有異步方法的服務(wù)契約。

所幸,在客戶端決定采用異步方式調(diào)用我所設(shè)計的服務(wù)操作時,雖然需要修改客戶端的服務(wù)契約接口,但并不會影響服務(wù)端的契約定義。因此,服務(wù)端的契約定義可以保持不變,而在客戶端則修改接口定義如下:

  1. [ServiceContract]  
  2. public interface IDocumentsExplorerService  
  3. {  
  4. [OperationContract]  
  5. Stream TransferDocument(Document document);  
  6. [OperationContract(AsyncPattern = true)]  
  7. IAsyncResult BeginTransferDocument(Document document,  
  8. AsyncCallback callback, object asyncState);  
  9. Stream EndTransferDocument(IAsyncResult result);  

注意,在BeginTransferDocument()方法上,必須在OperationContractAttribute中將AsyncPattern屬性值設(shè)置為true,因為它的默認值為false。

調(diào)用方式如下:

  1. BasicHttpBinding binding = new BasicHttpBinding();  
  2. binding.SendTimeout = TimeSpan.FromMinutes(10);  
  3. binding.TransferMode = TransferMode.Streamed;  
  4. binding.MaxReceivedMessageSize = 9223372036854775807;  
  5. EndpointAddress address = new EndpointAddress  
  6. ("http://localhost:8008/DocumentExplorerService");  
  7. ChannelFactory<IDocumentsExplorerService> factory =   
  8. new ChannelFactory<IDocumentsExplorerService>(binding,address);  
  9. m_service = factory.CreateChannel();  
  10. ……  
  11. IAsyncResult result = m_service.BeginTransferDocument(doc,null,null);  
  12. result.AsyncWaitHandle.WaitOne();  
  13. Stream stream = m_service.EndTransferDocument(result); 

如果采用SvcUtil生成客戶端代理文件,可以有更好的方式實現(xiàn)WCF異步調(diào)用,也就是使用SvcUtil的/async開關(guān),例如:

  1. svcutil /async http://localhost:8008/DocumentExplorerService 

唯一不足的是,它會不分青紅皂白,為所有服務(wù)操作都生成對應(yīng)的異步方法。這樣的做法未免過于武斷。

合理地利用服務(wù)的WCF異步調(diào)用,可以有效地提高系統(tǒng)性能,合理分配任務(wù)的執(zhí)行。特別對于UI應(yīng)用程序而言,可以提高UI的響應(yīng)速度,改善用戶體驗。在我編寫的應(yīng)用程序中,下載的文件如果很大,就有必要采用異步方式。

對于異步調(diào)用的完成,雖然WCF提供了諸如阻塞、等待和輪詢等機制,但***的方式還是使用回調(diào)。也就是利用Begin方法參數(shù)中的AsyncCallback對象。這是一個委托對象,它的定義如下所示:

  1. public delegate void AsyncCallback(IAsyncResult ar); 

利用WCF異步調(diào)用方式執(zhí)行服務(wù)操作,使得服務(wù)在執(zhí)行過程中不會阻塞主線程,當方法執(zhí)行完成后,通過AsyncCallback回調(diào)對應(yīng)的方法,可以通知客戶端服務(wù)執(zhí)行完畢。例如:

  1. //Invoke it Asynchronously  
  2. m_service.BeginTransferDocument(m_doc,OnTransferCompleted,null);  
  3. //Do some work;  
  4. //callback method  
  5. void OnTransferCompleted(IAsyncResult result)  
  6. {  
  7. Stream stream = m_service.EndTransferDocument(result);  
  8. result.AsyncWaitHandle.Close();  
  9. lbMessage.Text = string.Format("The file {0} 
    had been transfered sucessfully.",   
  10. m_doc.FileName);  

在調(diào)用BeginTransferDocument()方法之后,主線程不會被阻塞,仍然可以繼續(xù)執(zhí)行其它工作。而當服務(wù)方法執(zhí)行完畢之后,會自動調(diào)用回調(diào)方法,執(zhí)行方法中的內(nèi)容。

責任編輯:曹凱 來源: 博客園
相關(guān)推薦

2009-12-21 14:10:26

WCF異步調(diào)用

2009-11-09 10:50:30

WCF異步調(diào)用

2009-11-09 15:49:01

WCF異步調(diào)用

2009-11-06 15:54:15

WCF異步調(diào)用

2009-12-07 14:35:42

WCF異步調(diào)用

2009-12-07 14:26:47

WCF異步調(diào)用

2010-03-01 13:06:49

WCF繼承

2010-02-25 09:13:34

WCF異步調(diào)用

2009-12-21 14:49:27

2010-03-01 14:01:50

WCF服務(wù)異步調(diào)用

2010-03-01 17:52:03

WCF選擇綁定

2011-03-02 08:57:22

jQueryJavaScript

2012-10-29 10:59:27

Windows 8

2010-02-23 10:25:29

2009-12-22 18:43:00

WCF異步調(diào)用

2009-08-21 11:02:55

C#異步調(diào)用

2010-03-01 10:45:59

WCF集合類

2010-02-22 17:51:46

WCF傳較大數(shù)據(jù)

2010-02-22 17:58:06

WCF異步上傳

2009-10-20 16:48:30

C#委托
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 日本免费在线观看视频 | 欧美区日韩区 | 成人免费区一区二区三区 | 国产精品久久国产精品99 gif | 日韩欧美中文在线 | 久久久性色精品国产免费观看 | 狠狠综合久久av一区二区老牛 | 夜夜爽99久久国产综合精品女不卡 | 成在线人视频免费视频 | 中文字幕在线视频免费视频 | 国产精品亚洲一区二区三区在线 | 成人一区二区在线 | 性欧美精品一区二区三区在线播放 | 久久久久亚洲视频 | 欧美大片在线观看 | 中文字幕11页 | 亚洲综合区 | 国产精品一区久久久 | 日韩欧美在线观看视频 | 国产999在线观看 | 国产二区在线播放 | 91五月天| 婷婷色国产偷v国产偷v小说 | www.嫩草 | 亚洲色图综合 | 国产精品美女久久久久aⅴ国产馆 | 91精品国产综合久久久动漫日韩 | 国产精品视频网 | 国产999精品久久久久久绿帽 | 日韩欧美手机在线 | 国产精品久久久一区二区三区 | 天天干b| 欧美日韩在线免费观看 | 成人在线观看免费 | 国产中文原创 | 亚洲一一在线 | 欧美福利一区 | 欧美精品久久久久久 | 国产精品亚洲一区二区三区在线观看 | 国产免费又色又爽又黄在线观看 | 亚洲精品黑人 |