《Prism学习---实现可插拔的模块.docx》由会员分享,可在线阅读,更多相关《Prism学习---实现可插拔的模块.docx(5页珍藏版)》请在优知文库上搜索。
1、Prism学习(3)-实现可插拔的模块上一章中,我运用Unity重构了解决方案。不过在Application工程中仍旧须要引用其他各个依懒项。很明显,这样做并不能实现计算器模块的可插拔。今日,将以此为目标,对该解决方案进行再次的重构。首先,在运用PriSm框架加载的程序集中分别添加一个类,并让这些类实现IMOdUIe接口。当PriSm框架加载某个程序集后,将首先在程序集中搜寻实现了该接口的类。之后将会调用该接口的InitialiZe方法。于是,我们可以在这个方法中实现程序集内部的初化始操作,或者执行某个动作。通过这种机制,可以实现程序集的完全解藕。详细的操作如下:1.在CaIcuIator1.
2、ibrary程序集中添加一个类:CalcuIatorModuIe,并让其实现IMOdUIe接口。代码如下:2publicclassCalculatorModuIeJModuIe34publicCalculatorModule(IUnityContaiercontainer)56this.cotainer=container;78voidIModuIeJnitiaIizeO910container.RegisterType<ICalculator,Calculator>();llcontainer.RegisterType<ICalculatorRepl1.oop,Calcul
3、atorRepl1.oop>();12)1314IUnityContainercontainer;152.在InputOutput1.ibrary程序集中添加一个类:InpulOIRPUtMOdUIe,并让其实现IMOdUle接口。代码如下:2publicclassInputoutputModuIeJModuIe34publiclnputOutputModule(IUnityContainercontainer)56this.contaier=container;78voidIModuIeJnitiaIizeO910container.RegisterType<lInputServ
4、ice,ConsolelnputService>();llcontainer.RegisterType<IOutputService,ConsoleOutputService>(OutputServicel);12container.RegisterType<IOutputService,MSgBoXoUtPUtSerViCe>(OUtPUtSerViCe2);131415IUnityContainercontainer;163.在CommandParser1.ibrary程序集中添加一个类:InputoutputModuIe,并让其实现IMOdUIe接口。代码如
5、下:2publicclassInputParsingModuIe:IModuIe34publiclnputParsingModle(IUityCotainercontainer)56this.cotainer=container;78voidIModuIeJnitiaIizeO910container.RegisterType<llnputParserService,lnputParserSen/ice>();ll1213IUnityContainercontainer;144.在解决方案中新建一个类库:MainModuIe1.ibraryl在其中添加一个类:MainModuIe1
6、并实现IModUIe接口。这个类库将会作为计算器模块的入口,在该类的Initialize方法中将会启动计算器。代码如下:2publicclassMainModuIe:IModuIe34publicMaiModle(IService1.ocatorService1.ocator)56this.service1.ocator=Service1.ocator;78voidIModuIeJnitiaIizeO910IcalculatorRepI1.ooploop=11service1.ocator.Getlnstance<ICalculatorRepl1.oop>();1213loop.R
7、un();14)1516IService1.ocatorservice1.ocator;17到此,程序集部分的代码全部完成。可以看到,前三个程序集中ModUIe类,运用InitiaIiZe方法将各个类注册到了Container对象中,由PriSm框架进行管理。我们可以在须要的时候,在任何地方通过Prism框架将其取得调用;第四个程序集作为计算器的入口,在MOdUIe类的InitialiZe方法中启动计算器。这里的代码在上一章中基本都用过,在此不再描述。经过上面的修改,我们可以特别便利的对其进行调用,并且不须要任何的引用,实现了完全的解藕。下面的代码,将指示我们如何在主程序中启动这些程序集。如下
8、:2staticvoidMain(stringargs)34UnityContainerContainer=newUnityContainerO;56Container.Registerlnstance<IService1.ocator>(7newUnityservice1.ocatorAdapter(Container);89Container.RegisterType<IModulelnitializer,Modulelnitializer>();1011I1.oggerFacadelogger=newText1.ogger();12Container.Regist
9、erlnstance<I1.oggerFacade>(logger);1314Container.RegisterType<jIModuleCatalog,ConfigurationModuleCatalog>();1516Container.RegisterType<JModuleManager,ModuleManager>();1718IModuIeManagerManager=Container.Resolve<IModuleManager>();19Maager.Ru()20)上面的代码中,ModulelnitializerText1.ogg
10、er1ModuIeCataIog三个类,都是ModuIeManager的构造函数中所须要的。假如不注册,程序将会出错。在当前框架中,实现了I1.oggerFacade接口的类有多个。干脆运用RegiSIerType来注册,也将会报错,我没有看源代码,不知道他的名称是什么,所以在此干脆运用实体注册,这也可以实现同样的效果。在程序启动运行时,PriSm框架会去系统的配置文件中加获得模块的信息,并加它们加载到系统中。这些配置跟上一章中的类的配置不一样,详细请参考下面的xml文件:2<?xmlversion=1.0ecoding=tf-8?>3&l;COnfigUration>4&l
11、t;ConfigSeCtiOnS>5<sectionname=modules6type=Microsoft.Practices.Prism.Modularity1ModuIesConfigurationSectio,Microsoft.Practices.Prism/>7</COnfigSeetiOns>8<modules>9<moduleassemblyFile=CommadParser1.ibrary.dl,10modleType=CommadParser1.ibrary.lputParsigModule,CommandParser1.ibr
12、aryoIlmoduleName=Parsing7>12<moduleassemblyFile=Calculator1.ibrary.dll13moduleType=Calculator1.ibrary.CalculatorModule,CaIcuIator1.ibrarynMmoduleName=Calculator/>15&忙moduleassemblyFile=lnput0utput1.ibrary.dll16moduleType=lputOtpt1.ibrary.lnputOutputModule,lput0utput1.ibrary17moduleName=lnpu
13、tOutput7>18<moduleassemblyFile=MainModule1.ibrary.dl,19modleType=MaiModule1.ibrary.MaiModle,MainModule1.ibrary20moduleName=Main>21<dependencies>22<dependencymodleName=,Parsig/>23<dependencymoduleName=Calculator/>24<dependencymoduleName=lnputOutput7>25</dependencies>26</module>27</modules>28</configuration>到此,计算器模块的完全解藕顺当完成。我们可以删掉Application中对计算器模块的全部弓I用。将其它模块编译好后,拷到APPIiCaiion项目的DebUg书目下试一下。这个项目,只是PriSm框架的一个简洁应用。在后续的章节中,我将接着深化探讨对该框架的运用。欢迎大家一起来学习PriSm框架,共同进步。请大家多多指教。