插件式的应用程序架构模型
概述
说起插件(Plug-in)的应用程序,我印象最为深刻的是一款很流行的MP3插放软件,Winmap,这是我最早看到的和最先使用的插件式设计的应用程序,使用Winmap的插件管理器,可以扩展Winmap的功能,加入用户下载的或个人开发的插件,如音乐效果器,皮肤,甚至是歌词显示的面板!
这样的应用程序还有 Photoshop, 它使用插件模式管理它的滤镜
还有很多一些大一点的应用程序或开发工具,基本都是使用了插件式的程序框架,Visual Studio,Office,Eclipse,Delphi等等,Eclipse更是将插件模式开发到了极至,因为Eclipse是开源,在全世界有众多的支持者,并且又有IBM在后面撑腰,所以Eclipse拥有让人应接不暇的插件,以至现在一说起插件框架,所有人立刻想了Eclipse。事实上,插件框架不是什么新鲜的事物,早在十几年前就有了(当然是别人评语,本人那时还没有出生,Eclipse出现时我还不是程序员),像X Server,是基于插件式开发的,除了核心功能外,它所有的扩展功能和设备功能都是以插件方式加进去的。
插件式的开发有什么好处呢?
当为你自已的应用程序采用哪种架构时,应该先进行思考,相对于别的构架,如MVC,CS,有什么不同的特点,和相对于它们的优点,在我看来,这种开发的优点是显而易见的,比如,减少你的程序之间的耦合,各种插个都是独立的,作为一个单独的功能模块,它的主程序只是一个框架,真正的具体功能只能通过插件来抻供,功能与框架没有直接关联。其次,它隔离了功能的变化,增加新的功能时,无须修改现在的代码,例如,在插件的图象浏览器中,增加新的图象处理功能,只需要增加一个插件就行了,便于团队的合作开发,当插件的契约订好后(也可以理解为协议,标准接口),新增的功能可以分派到各个团队成员个人开发,最后,最大的好处,就是可以将整个系统的复杂度减下来,具体的功能细化到插件,整个系统的开发工作量虽然没有减少,但是系统的功能剥离后整个构架都清晰了!
(最近时间有点空闲了,现在是想着把Libra的开发总结一下,不知什么时候工作再忙的时候,又再被自已拿什么借口偷懒了!)