掃二維碼與項目經(jīng)理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
原來上網(wǎng)我下了很多WCF異步調(diào)用Demo。而我用的是VS2005,我在使用這些小樣時,基本上絕大部分基于VS2003的Asp.net工程都因?yàn)樯贁?shù)文件無法轉(zhuǎn)換而無法加載工程,為此我也苦惱很久,后來終于讓我找到了解決辦法。

一個好的框架設(shè)計要素在于,不管客戶端的調(diào)用方式(同步或者異步),服務(wù)的設(shè)計與實(shí)現(xiàn)應(yīng)該是一致的。對于服務(wù)的設(shè)計者而言,在設(shè)計之初,就不應(yīng)該去考慮服務(wù)的調(diào)用者調(diào)用的方式。換言之,服務(wù)操作究竟是否采用異步方式,應(yīng)該由客戶端的調(diào)用者決定。
因此,所有與異步調(diào)用相關(guān)的內(nèi)容應(yīng)該只與客戶端相關(guān)。 標(biāo)簽:WCF異步調(diào)用【引自張逸的博客】WCF與Web Service不同的是,當(dāng)我們定義了服務(wù)契約的操作時,不管是通過ChannelFactory創(chuàng)建服務(wù)代理對象,還是通過SvcUtil的默認(rèn)方式生成服務(wù)代理對象,客戶端在調(diào)用這些代理對象時,都無法直接實(shí)現(xiàn)異步方式的調(diào)用。例如,對于如下的服務(wù)操作定義:
- [OperationContract]
- Stream TransferDocument(Document document);
在調(diào)用代理對象的方法時,我們無法找到對應(yīng)于TransferDocument()操作的BeginTransferDocument()和EndTransferDocument()異步方法。這樣的設(shè)計使得我們無法通過編程方式異步地調(diào)用服務(wù)的操作,除非我們在定義服務(wù)接口時,直接加入相關(guān)操作的異步方法。
然而,這又直接導(dǎo)致了服務(wù)的設(shè)計與方法調(diào)用方式之間的耦合。一個好的框架設(shè)計要素在于,不管客戶端的調(diào)用方式(同步或者異步),服務(wù)的設(shè)計與實(shí)現(xiàn)應(yīng)該是一致的。
對于服務(wù)的設(shè)計者對WCF異步調(diào)用而言,在設(shè)計之初,就不應(yīng)該去考慮服務(wù)的調(diào)用者調(diào)用的方式。換言之,服務(wù)操作究竟是否采用異步方式,應(yīng)該由客戶端的調(diào)用者決定。因此,所有與異步調(diào)用相關(guān)的內(nèi)容應(yīng)該只與客戶端相關(guān)。WCF遵循了這一規(guī)則。#t#
在我編寫的應(yīng)用程序中,會暴露一個傳送文檔文件的服務(wù)操作。我并不知道也并不關(guān)心調(diào)用該操作的客戶端是否采用異步方式。因此,如上所述的服務(wù)操作定義是完全正確的。

我們在微信上24小時期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流