基于Eclipse RCP简化IoC实现2011-01-05 天极 朱先忠一.引言Eclipse富客户端平台(RCP)是一个强有力的软件基础库-它基于相互联系的协作性插件,允许开发者构建普通应用程序。借助于RCP,开发者只需专注于应用程序业务代码的开发而不必花时间去重写应用程序管理逻辑。控制反转(IoC)和依赖性注入(DI)都是能够用来减少程序之间的耦合度的编程模式。它们都遵循一种简单的原则:你不必创建自己的对象,而只需描述该对象如何被创建;你不必实例化或直接定位你的组件需要的服务,而只需确定哪些服务为哪些组件所需要,然后由其它程序(通常是一个容器)负责把它们"钩"到一起。这就是著名的"好莱坞原则"-不要找我们,让我们找你好了。本文将描述一种把依赖性注入支持功能加入到一个Eclipse RCP应用程序中的简单方法。为了避免影响Eclipse平台基本结构并且为了把IoC框架透明地添加到RCP,我们将联合使用运行时刻字节码操作技术(使用ObjectWeb ASM库),Java类加载代理(使用java.lang.instrument包)和Java注解技术。二.什么是Eclipse丰富客户端平台?用一句话来概括,Eclipse富客户端平台就是用于构建既能独立运行又能在网络中运行的应用程序的一组库,软件框架及一个运行时刻环境。尽管Eclipse被作为一种开发程序的IDE来使用;但是,整个软件自从3.0版发行以来被重新构建成各种独立的组件,以便可以使用这些组件的最小子集来构建任意的应用程序。这样的一个子集构成了丰富客户端平台并且包括不同的元素:基本运行时刻,用户接口组件(SWT和JFace),插件,还有OSGi层。图1展示了Eclipse平台的主要组件构成。

图1.Eclipse平台的主要构成组件整个Eclipse平台基于两个关键概念-插件和扩展点。一个插件是一个小的功能单元,它能够被独立地开发和发布。典型情况下,插件被打包为一个jar文件,并且能够通过添加某种功能来扩展Eclipse平台(例如,一个编辑器,一个工具栏按钮或一个编译器)。其实,整个Eclipse平台就是一组相互连接的彼此之间能够进行通讯的插件。一个扩展点是一个可用的连接点,其它的插件可以用来提供添加的功能(用术语来说,就是"扩展")。扩展和扩展点都是在与插件绑定到一起的XML配置文件中定义的。尽管插件机制利用了重要的模式-例如关系分离,强连接等等;但是,插件需要的通讯能够导致这些插件间的物理依赖性。典型的例子就是,插件需要定位可用于应用程序的单例(singleton)服务-例如数据库连接池,日志处理或用户保存的收藏信息。控制反转和依赖性注入都是去除这种依赖性的可行方案。