用Qi4j进行面向组合编程 - 编程入门网
进行设计的。我们对类似如下的设计图已经非 常熟悉了:
这个图包含有多个模块,不同模块构成了不同层,而各层又叠放在一起。我们 可将这种设计方法简称为LMM(Layered Modules Metaphor,分层模块表示法)。 LMM图可用来传达一个整体应用的总括,不让我们陷入太多的细节当中。严格按照 LMM的要求设计系统,可减少系统缺陷、降低长期维护成本,这种系统对未来变更 的反映也可更为灵活。绝大多数项目都使用LMM来描述应用程序的构成方式,许多 项目设法遵循LMM,但只有很少的项目是按此执行的。我想我们都已经看到过很多 惨痛教训,比如在基础结构层的类中直接使用Web层的类。 用Qi4j进行面向组合编程(2)时间:2011-07-08 infoqQi4j支持的结构 Qi4j目前已经能为LMM提供明确的支持,这有助于规范团队中开发人员的行为 。Qi4j应用结构是一个小规则集: 结构 所有结构在应用启动时静态声明 所有Composite实例都有所属模块 所有服务都有所属模块 所有模块都有所属层 所有层都有上下层次关系(但不循环) 所有层一起构成了应用 访问 模块能访问同层的所有其他模块 层能访问它的直接下级层(不能跃层访问) 可见性 Composite实例缺省只在所属模块内可见 Composite实例也能设置为在层内或层间可见 看起来比较复杂,其实不然。本质上,Composite实例在创建它们的模块中都 是私有的,除非显式声明为对模块外或层外公开。这和在普通Java中使用 “public”和“pirvate”修饰词限定类的可见性是类似的。 Qi4j目前尚不提供其他可供选择的结构,但其包含了构造常用应用程序结构的 简单方法(包括一个层中只包含一个模块的情况)。 结构的使用 领域代码无需了解应用程序结构,但可以用@Structure注解的形式出现。如下 例所示: CompositeBuilderFactory将在创建时被注入Mixin,而且它仅允许代码实例化 结构中可见的Composite。 结构发挥作用的另一个常见例子发生在查找服务时。若在相同模块中有且仅有 一个要求类型的服务,那么就无需引入额外装配(Assembly)。服务的使用变得 十分简单。 例如,如果服务GenericInventory被声明在Bread模块中,那么每个inventory 服务实例都将受其邻近各自客户端的程度约束。 用Qi4j进行面向组合编程(3)时间:2011-07-08 infoq应用结构的生成 Qi4j 应用需通过应用程序代码实现自举,最简单的启动方法大致如下: 另外,还可利用SingletonAssembler编写上述功能: SingletonAssembler是一个用于创建单层单模块Qi4j应用程序的工具类。 newApplication()方法也可接收Assembly[][][]类型的参数,由此可创建“千 层饼式”分层结构的应用环境(除了第一个和最后一个层,其他都有相邻的上、 下层)。例如: 用Qi4j进行面向组合编程(4)时间:2011-07-08 infoq上面代码实现的结构如下图示: 最后,如果应用程序结构十分复杂,还可将ApplicationAssembly实例作为参 数传递给newApplication()方法。 ApplicationAssembly用类似迭代的形式创建 全部LayerAssembly,再为每个LayerAssembly创建 ModuleAssembly。举例如下: 运行上面代码可得到如下结构: 用Qi4j进行面向组合编程(5)时间:2011-07-08 infoq结构化的好处 通过代码显式实现应用程序结构有两个显著的好 处: 就近访问。 架构强制执行。 这意味着,越近的 Composite优先级越高,越易访问;外部不能访问模块或层内私有的Composite。 因为服务被实现为Composite,其解析方法更为含蓄,需要的装配配置也少得多。 Qi4j结构概念的另一个有趣之处在于每个应用都有一个静态结构组合,它 可以通过工具来抽取并展示,而不必单独维护。这使得架构师、设计师或团队负 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |