999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

基于MEF技術(shù)的程序解耦探究

2015-05-30 10:48:04徐龍
科技尚品 2015年8期

徐龍

摘 要:利用插件技術(shù),人們可以隨時擴展宿主程序的功能,這不僅提高了程序的擴展性,也降低了宿主程序域各插件功能上的耦合,使程序變得更加容易維護。

關(guān)鍵詞:NET Framework;MEF;插件;解耦

1 MEF介紹

Managed Extensibility Framework(MEF)是.NET平臺下的一個擴展性管理框架,它是一系列特性的集合,包括依賴注入等。MEF為開發(fā)人員提供了一個工具,讓我們可以輕松地對應(yīng)用程序進行擴展并且對已有的代碼產(chǎn)生最小的影響。在開發(fā)過程中,研發(fā)人員可以根據(jù)業(yè)務(wù)需求定義一些擴展點,在后期的維護中便可使用這些擴展點與應(yīng)用程序交互;同時MEF使得宿主程序與擴展程序之間不產(chǎn)生直接的依賴,這樣做的好處之一是多個具有同樣的擴展需求之間可以很容易共享擴展程序。

1.1 MEF體系結(jié)構(gòu)

MEF通過部件和容器來構(gòu)建。容器在類別中查找部件,類別在程序集或目錄中查找部件。容器把入口連接到出口上,部件因此可以用于宿主應(yīng)用程序。

MEF的核心技術(shù)是組合部件,它由一系列特性來描述和創(chuàng)建。每一個部件通過附加Export特性向其他部件提供功能,并通過附加Import特性來引用其他部件的功能。創(chuàng)建一個部件后,通過在定義好的部件目錄中查找需要的功能來實現(xiàn)部件的組裝。

MEF包括3大類別:用于宿主的類、基元類和基于特性機制的類。宿主類包含類別和容器。基元類可以用作基類,來擴展MEF體系結(jié)構(gòu),以使用其他技術(shù)連接出口和入口。通過反射構(gòu)成基于特性機制的實現(xiàn)方式的類,如Export和Import特性等,提供擴展方法,便于使用的基于特性的部件的類,這些也是MEF的一部分。

1.2 MEF部件的構(gòu)建過程

通過以下步驟便可輕松構(gòu)建MEF程序:

(1)定義部件目錄

(2)創(chuàng)建部件容器

(3)創(chuàng)建部件

(4)部件組裝與實例化

1.3 聲明一個部件

導(dǎo)出是部件向容器中的其他部件提供的一個值,而“導(dǎo)入”是部件向要通過可用導(dǎo)出滿足的容器提出的要求。在特性化編程模型中,導(dǎo)入和導(dǎo)出是由修飾類或成員使用Import和Export特性聲明的。Export特性可修飾類、字段、屬性或方法,而Import特性可修飾字段、屬性或構(gòu)造函數(shù)參數(shù)。為了使導(dǎo)入與導(dǎo)出匹配,導(dǎo)入和導(dǎo)出必須具有相同的協(xié)定。

1.4 部件的生命周期

由于部件承載于組合容器中,因此其生命周期可能比普通對象更復(fù)雜。需要在關(guān)閉時執(zhí)行工作的部件和需要釋放資源的部件應(yīng)照常為NET Framework對象實現(xiàn)IDisposable。但是,由于容器創(chuàng)建并維護對部件的引用,因此只有擁有部件的容器才應(yīng)對其調(diào)用Dispose方法。容器本身實現(xiàn)IDisposable,并且作為Dispose中其清理的一部分,它將對擁有的所有部件調(diào)用Dispose。因此,當不再需要組合容器及其擁有的任何部件時,您應(yīng)始終釋放該組合容器。

2 利用MEF技術(shù)解耦程序

下文通過開發(fā)簡單的數(shù)據(jù)庫入庫工具來逐步說明。

2.1 簡單的入庫工具

假設(shè)需要開發(fā)一款數(shù)據(jù)庫入庫工具,并且準備采用SQL Server作為數(shù)據(jù)庫管理系統(tǒng),可以使用在.NET下ADO.NET 進行數(shù)據(jù)庫訪問。

如果使用一段時間后,需要兼容其他的數(shù)據(jù)庫,如Oracle、MySql等,這就可能需要修改代碼,以適應(yīng)新的需求。

很顯然,訪問數(shù)據(jù)庫的業(yè)務(wù)邏輯與主程序產(chǎn)生了緊耦合,使得程序在需求改變后很難擴展,這不符合OCP(Open-Closed Principle)原則。

2.2 利用MEF技術(shù)實現(xiàn)解耦

上述問題如果使用MEF技術(shù)則很容易解決。將入庫工具看作宿主程序,將入庫的具體業(yè)務(wù)放入插件中執(zhí)行。通過添加插件來實現(xiàn)兼容不同的數(shù)據(jù)庫。

2.2.1 定義Import類型

在宿主程序中添加類型為IDataAccess的屬性,并將Import特性附加其上。這樣在程序運行中,部件在目錄中查找接口協(xié)定,并實例化。而部件的組裝是通過反射技術(shù)動態(tài)進行的,這樣便可在任何時候在滿足接口協(xié)定的情況下根據(jù)需要來實現(xiàn)IDataAccess。

應(yīng)當將IDataAccess放在獨立的程序集中,這樣宿主程序集和插件程序集可以分別引用IDataAccess所在的程序集,從而避免了宿主程序集直接應(yīng)用插件程序集而產(chǎn)生不必要的耦合。

2.2.2 定義Ecport

在實現(xiàn)IDataAccess的類中,需要加入Export特性,這是插件實現(xiàn)個關(guān)鍵步驟。因為部件在組裝過程中根據(jù)Export特性來匹配和實例化。

MEF時基于反射來實現(xiàn)的。這樣在后期需要兼容其他數(shù)據(jù)庫時,只要新建獨立的程序集并使用需要的數(shù)據(jù)庫訪問類實現(xiàn)IDataAccess接口,將上述程序集拷貝到宿主程序的運行目錄中即可。

2.2.3 部件組裝

部件組裝很容易實現(xiàn),只需定義部件目錄DirectoryCatalog,并使用上述對象實例化部件容器CompositionContainer,同時使用部件容器的ComposeParts()方法,從特性化對象中創(chuàng)建可組合部件,并在當前容器中組合這些部件。只需3行代碼便可完成部件的組裝,具體如下:

var catalog = new DirectoryCatalog(AppDomain.CurrentDomain.BaseDirectory);

var container = new CompositionContainer(catalog);

container.ComposeParts(this);

3 總結(jié)

MEF的組合基元是可擴展支持的本質(zhì),它看起來顯得非常的簡單,但卻有能夠支持強大的功能并且不失靈活性。上例中正是利用這種原理輕松的實現(xiàn)了主程序與具體的業(yè)務(wù)之間的解耦。

參考文獻

[1]ChristianNagel ProfessionalC#4and. NET4[M].清華大學(xué)出版社,2010.

(作者單位:安徽四創(chuàng)電子股份有限公司)

主站蜘蛛池模板: 激情六月丁香婷婷| 五月天香蕉视频国产亚| 麻豆精品在线| 欧美激情,国产精品| 婷婷综合缴情亚洲五月伊| 国产成人综合久久精品尤物| 青青热久麻豆精品视频在线观看| 欧美日韩国产在线播放| 国产成人亚洲日韩欧美电影| 精品人妻无码中字系列| 色综合激情网| 欧美成人影院亚洲综合图| 不卡国产视频第一页| 国产精品亚洲一区二区在线观看| 亚洲欧美成人综合| 91黄视频在线观看| 亚洲欧美日本国产专区一区| 国产午夜看片| 在线看国产精品| 91视频精品| 亚洲精品va| 久青草免费在线视频| 亚洲精品午夜天堂网页| 国产精品福利导航| 全部毛片免费看| 国产精品19p| 久无码久无码av无码| 欧美性色综合网| 国产jizz| 蜜桃臀无码内射一区二区三区| 91免费片| 四虎永久在线| 婷婷亚洲最大| 亚洲午夜国产片在线观看| 国产精品999在线| 91精品久久久久久无码人妻| 在线欧美日韩| 国产成人综合网| 无码区日韩专区免费系列| 国产美女丝袜高潮| 国产拍揄自揄精品视频网站| 国产一区二区色淫影院| 国产精品视频a| 91免费国产在线观看尤物| 欧美色伊人| 国产成人精品高清不卡在线| 超薄丝袜足j国产在线视频| 国产一区二区丝袜高跟鞋| 国产日韩欧美精品区性色| 九九九国产| 啊嗯不日本网站| 亚洲天堂777| 国产91av在线| 综合色在线| 国产成人午夜福利免费无码r| 亚洲毛片一级带毛片基地 | 好紧好深好大乳无码中文字幕| 国产精品视频999| 国产无码性爱一区二区三区| 在线毛片网站| 在线观看视频99| 亚洲日本中文字幕乱码中文| 成人国产一区二区三区| a网站在线观看| 中文字幕人成人乱码亚洲电影| 久久人人妻人人爽人人卡片av| 91精品综合| 国产极品美女在线| 免费在线成人网| 狠狠色噜噜狠狠狠狠色综合久| 欧美日本在线一区二区三区| 国产性猛交XXXX免费看| 国产一级片网址| 老司机精品一区在线视频| 性色一区| 色哟哟色院91精品网站| 欧美成a人片在线观看| 亚洲天堂网视频| www.91中文字幕| 91精品啪在线观看国产91| 日本人真淫视频一区二区三区| 亚洲性影院|