`
chinajavawolf
  • 浏览: 116809 次
  • 性别: Icon_minigender_1
  • 来自: 哈尔滨
社区版块
存档分类
最新评论

(C1)Tapestry IoC:Introduction

阅读更多
本人翻译目的是用来学习Tapestry5的,共享出来希望大家批评指正。计划持续翻译。
chinajavawolf  
Tapestry IoC 容器
 
Tapestry框架的内部结构基于IoC控制,这种设计方法允许工作系统被许多小的,易测试的块构成。
 
使用 IoC(控制倒转) 的额外好处是,通过打破一个复杂的系统为小的块,使它变为比较容易修正和扩充的系统(通过丢弃或更换系统的小块)。
 
Tapestry中使用IoC代表了从Tapestry3Tapestry4Tapestry5的发展。Tapestry3没有使用IoC,尽管它包括一些不牢固机制,例如扩展,但它服务于同样的目的。要使Tapestry的行为有大规模的变化需要子类的关键类和最重要的方法。
 
Tapestry4引入了 HiveMind IoC容器。事实上,HiveMind 工程被明确创建为Tapestry4使用的IoC容器。Tapestry4 已经基本上实现了可扩展性和可配置性的目标,这主要是因为HiveMind的弹性。
 
Tapestry5扩充了这些,使用了一个明确为Tapestry建造的容器代替HiveMind,为更易使用,表现和性能设计。并且他可以被其他的Tapestry独立使用。
 
  • 为什么不是Spring?
 
Spring是一个非常成功的IoC容器工程。Spring工程结合了一个非常好的 IoC容器,集成了AspectJ支持和很多构建在容器之上的库。Spring是一个很好的应用容器,但是对于框架容器它缺少很多必须的特性:
1.          Spring beans可以通过name(或id)被连在一起,但是它不可能引入附加命名抽象。Tapestry4 的"infrastructure:"抽象的关键在于它允许你可以很容易地现场替换Tapestry内部服务而无须复制大的web的相关服务(将近200Tapestry4.0)
2.          虽然Spring允许beans被拦截,但是,它以一个新的bean的形式这么做,让未被拦截的bean可见(并不可能会被滥用)。HiveMind和Tapestry IoC 包裹服务在拦截器内,防止未拦截的访问执行核心服务。
3.          Spring的XML配置文件相当冗长,与同等的HiveMind XML 文件相比,也常常如此。这在Spring 2.0中已经被改进了。
4.          Spring有一个简单的 map/list/value 配置方案,但它不是分散的。它是一个单独的bean定义的一部分。HiveMind和Tapestry5 IoC允许服务配置从多个模块装配。这是非常重要的对于框架的无缝扩展,使用零配置(仅仅放下模块在 classpath 内然后和所有钩子一起)。
  • 为什么不是 HiveMind?
 
管理两个复杂框架的发布进度的困难已经被证实是个问题了。HiveMind2.0版将融合那些当前在Tapestry5 IoC容器内的思想,但也将继续维持遗留所支持的现有XML-driven方法。
 
HiveMind的使用也涉及到一个Tapestry4中的一个共同问题:启动时间。这个时间是用来解析和组织所有XML显示的,要用几秒的启动时间。它被希望创建一个改进的IoC容器不用依靠XML驱动,这将减少很多问题。
 
着新技术(尤其是JDK1.5 的标注, 和通过Javassist产生的运行时类)的到来,HiveMind中的一些规则已遭到破坏。这就是说,在HiveMind(Spring)内,所有XML都是一种笨拙的方式来描述几个基本的Java操作:具体的类和在那些类上调用的方法 (注入依赖在具体的实例上)。Tapestry IoC中的重要概念就是消除XML并且在简单对象和方法周围构建一个同等系统。
 
Tapestry IoC同样代表了很多HiveMind的简化,代表了当创建HiveMindTapestry4时从两者学来的经验教训。
 
目标
关于Tapestry5,大体上,Tapestry IoC的目标是更简单,更健壮并且避免XML
 
现存的IoC容器比如HiveMind和Spring包含了大量的XML配置来描述怎样和何时实例化一个详细的JavaBean,和如何使用依赖提供给那个bean(不是通过构造器注入就是通过属性注入)。其他的XML被用来钩住对象进入生命周期内。。。当对象被实例化和配置时,或者当它被丢弃时,典型的callback方法被调用。
 
Tapestry IoC的核心概念是Java语言自身是更容易和简洁描述对象生产和方法调用的方法。在XML中的任何近似方法最终都是更冗长和更难处理的。就像例子显示的,一小块Java 代码和一些命名约定还有标注要比一大块XML更简洁和容易。
 
另外,从XML转移到Java代码更便于测试;你可以对你的模块构建者类的服务构建者方法进行单元测试,但你不能如实地单元测试你的XML描述符。
 
Tapestry IoC模块更容易打包成JAR文件,支持零配置使用:仅仅放置JAR到classpath上。
 
另一个目标是“开发者友好”。这是一个真实的横切关注点,并不太可能任何时候都很快被包装成一个切面。Tapestry IoC框架被设计为容易使用和理解的。此外,当有错误发生时,它都积极尝试通过全面的检查和准确的错误信息帮助你。另外,所有用户可见的对象都实现了一个合理的toString()方法,以此来帮助你理解是怎么回事,当你不可避免的试图在调试器中解决问题时。
 
在使用Tapestry IoC构建服务方面。。。目标是“灵活”,借用棋盘游戏的术语。两个游戏者放置石头在开始的空棋盘上,创建围墙来圈入领土或者除去对手放置的石头界线。游戏最后胜利者要控制最大多数的领土,而且玩这个游戏,在占据领土和防护现有领土之间是不变的制约平衡。玩石头的地界要“轻巧灵活”(或者有“好的形状”),当在棋盘上用最少的石头控制最大的面积时。如果玩石头的地界是“繁琐笨重”的正好给你的对手一个好机会去控制棋盘上的另一个区域。
 
在软件开发中,我们也努力通过简单的块创建复杂的系统,但是我们的制约平衡源自增加功能性平衡的需求与测试和维护现有代码的需求相反。通常在软件开发的世界里,所有增加功能性,测试和维护的请求都是被延期的。。。。直到为时已晚。
 
IoC容器是的一般性的,Tapestry IoC非常明确,尝试解决这个问题,为平衡快速增加功能性的需求和相对的测试新的功能性和维护现有功能性的需求提供基础。IoC容器提供手段来打破大的,复杂的,整块的为简单的,小的,可测试的块。
当构造一个服务的注册库(registry)时,灵活性是指以适当的责任分工,分离关注并限制系统的各部分依赖关系。这种风格常被称为迪米特法则(Law of Demeter. 使用IoC容器使它更容易包含这个方法,因为临界相关, 哪个对象负责实例化哪个其他对象,完全是通过容器管理。除去生命周期关系,它变得非常容易将复杂的大块代码缩减成小的,可测试,可再用的服务。
 
"轻巧灵活" 的含义:
 
1.       有两个或三个方法的小接口
2.       有两个或三个参数的小方法(因为依赖被注入在后台优于在方法中传递)。
3.       匿名通讯途径事件优于外在方法调用。这个服务实现可以实现一个事件监听接口。
 
术语
 
在Tapestry IoC内的基本单位是一个服务。一个服务由一个服务接口和一个服务实现组成。这个服务接口是一个普通的Java接口。这个服务实现是一个实现了服务接口的Java对象。通常,每个服务接口将只会有一个单独的服务,但是在某些情形下,有可能是很多不同的服务和服务实现都共享这个相同的服务接口。
 
服务通过一个唯一的id被识别。典型的,一个服务的id匹配这个服务接口的绝对名,但这仅仅是个约定。
 
服务被合成到模块内:
 
1.       一个模块通过模块构建器被定义,一个具体类,包含各种静态或实例方法,用来确定服务,装饰他们(见下文),或贡献用于服务配置(再看,更下面的下文).
2.          模块构建器类的方法定义的这个服务通过这个模块被提供,并且同样的方法负责实例化这个服务的实现。
 
这个被定义的方法和构造服务被称为服务构建器方法。.
 
注册库(registry)是这个模块和服务的外界视图。从注册库获得服务是可能,经由唯一的id或通过它的服务接口。通过唯一id访问是万无一失的。(意味着,一个匹配将被发现即使key值搜索不匹配服务自身)。
 
服务可能通过服务修饰器方法被修饰。这些方法创建了拦截器对象,捆绑在核心服务实现的周围,添加行为,比如日志,安全访问,或者是事务管理。拦截器实现相同的服务接口作为服务。控制放弃被应用给服务的修饰器内的顺序。
 
服务可以有一个配置。这个配置可以是一个map,或者是一个collection,或者是一个有序的list。这个服务定义的对象类型允许被贡献在配置中。这个配置的构造来自于一个或多个模块提供的贡献。服务构造器方法被调用给配置中的贡献对象。
 
注意:在HiveMind中,服务和配置是隔离的,这往往导致连接一对相同名字的服务和配置。对于Tapestry IoC,每个服务都被允许有一个单独的配置,这通常足够了。
 
服务被实例化是被需要的(need)。在这种情形下,“need”转变为“当一个服务的方法被调用时”。一个服务被表现(对于外界,或对于其他服务)为一个实现了服务接口的代理。首先一个方法在代理上被调用,整个服务(由实现了任何包裹了的拦截器的核心服务组成)被构造。这发生在一个完全线程安全的方式下。JIT(即使生产Just-in-time)实例允许更复杂,更细粒级的网络服务,并且改善启动时间。
 
当这个服务被构造又可见时,服务要定义一个控制范围。默认的范围是单例(singleton),意味着当被需要时一个单独的目标实例被创建。其他的范围允许服务实现被绑定的当前线程(即目前要求在一个servlet应用内)。
 
依赖是一个服务实现需要其他的服务(或其他的对象)。这些依赖可以被注入在服务构建器方法中并给予提供,从那,经由他的构造器或经由他的服务实现上的方法给一个服务实现。这些也可以作为合作者被查阅,尤其在写的单元测试的上下文内。
 
分享到:
评论

相关推荐

    tapestry5.3.5 IOC用户登陆权限

    在Tapestry中,IOC容器负责管理对象的生命周期和依赖关系,包括安全相关的服务。 在Tapestry 5.3.5中,实现用户登录权限通常涉及以下几个关键知识点: 1. **身份验证服务**:这是处理用户身份验证的核心组件。通常...

    tapestry-ioc-5.0.3-src

    在"tapestry-ioc-5.0.3-src"这个压缩包中,我们可能找到Tapestry IOC框架的源代码,这对于开发者深入理解其工作原理和定制功能非常有价值。 1. **依赖注入(DI)**:Tapestry IOC的核心概念就是DI,它允许对象在...

    tapestry源码 api等

    1. **Tapestry Core**: 这是Tapestry框架的基础部分,包含了核心组件、服务容器(Tapestry IoC)和页面生命周期管理。通过源码分析,我们可以理解其如何实现页面组件的渲染、事件处理和依赖注入。 2. **Tapestry ...

    Tapestry 5.4.1 相关jar文件

    2. **tapestry-ioc.jar**:Tapestry依赖注入(IoC)容器,用于管理对象的创建、配置和生命周期,使得代码更加松耦合。 3. **tapestry-webresources.jar**:处理静态资源如CSS、JavaScript和图片,支持压缩、合并和...

    Tapestry开发

    <tapestry:propertySelection name="country" label="Country" model="${countries}" /> ``` **14. Table组件:** - **用途:**用于创建表格。 - **示例代码:** ```xml <tapestry:table data-model="${users}...

    apache-tapestry-5.3.8-bin.zip

    4. **Tapestry IoC (Inversion of Control)**:`tapestry-ioc-5.3.8.jar`实现了依赖注入容器,使得对象的创建和管理变得更加简单,同时也促进了代码的解耦。开发者可以声明服务并定义它们之间的依赖关系,IoC容器会...

    优化大使tapestry-bin-5.0.18.zip

    这个压缩包包含了多个以"Tapestry"开头的子文件,如 "tapestry-core", "tapestry-hibernate", "tapestry-ioc", "tapestry-upload", 和 "tapestry-spring",这些都是Tapestry框架的不同模块或插件。这些文件的后缀是...

    tapestry学习入门资料

    "tapestry学习入门资料" Tapestry 是一个开源的基于 servlet 的应用程序框架,它使用组件对象模型来创建动态的、交互的 web 应用。 Tapestry 使得 Java 代码与 HTML 完全分离,利用这个框架开发大型应用变得...

    Tapestry.5.Building.Web.Applications.pdf

    《Tapestry 5.0:构建Web应用程序》是一份专为深入了解Tapestry 5.0框架而准备的详细指南。Tapestry是Apache软件基金会的一个开源项目,它提供了一种基于Java的声明式MVC(Model-View-Controller)框架,用于构建...

    Tapestry5.0.7

    - **tapestry-ioc**:Tapestry 的依赖注入和服务容器模块,是Tapestry的核心组件之一。 - **tapestry-tutorial1**:可能是一个示例教程项目,帮助开发者学习和理解Tapestry的基本用法。 - **tapestry-annotations*...

    Tapestry字典0.1.pdf

    - **实现方式**: 通过`<tapestry:link>`标签或`<tapestry:component>`中的`href`属性来实现页面间的跳转。 - **应用场景**: 用户操作后导航到新的页面。 **1.3 初始化** - **初始化方法**: `init()`方法是在组件...

    tapestry5.2.6 jar包

    6. **Spring集成**:通过tapestry-spring模块,Tapestry可以与Spring框架协同工作,利用Spring的IoC容器管理服务和bean。 7. **测试支持**:Tapestry-test模块提供了专门的测试工具,使得开发者能够对组件进行单元...

    tapestry-bin-5.1.0.5

    4. **tapestry-ioc-LICENSE.txt**:这部分涉及Tapestry的依赖注入(IOC)框架,它是Tapestry实现组件之间解耦的关键部分。 5. **tapestry-upload-LICENSE.txt**:关于Tapestry中文件上传功能的许可信息,帮助开发者...

    Tapestry4开发指南

    然而,随着时间的推移,Tapestry4展现出的独特优势逐渐显现,尤其是其通过Hivemind提供的IoC和DI(Dependency Injection)机制,使得开发者能够根据具体需求重构Tapestry4的组件,从而实现更为个性化、符合特定场景的...

    tapestry5 build web application-alexander

    《Tapestry 5:构建Web应用程序》是关于Tapestry 5框架的一本权威指南。Tapestry 5是一个强大的Java Web应用框架,由Apache软件基金会开发并维护,它致力于提供一种更高效、更优雅的方式来构建动态、交互式的Web应用...

    tapestry官方中文文档

    Tapestry是一款强大的Java Web应用程序框架,由Apache软件基金会维护,它强调了组件化、模块化和可重用性,使得开发复杂的Web应用变得更加简单。本文将深入介绍Tapestry 4的相关知识点。 1. **组件化编程**: ...

    Tapestry5, Packt.Publishing.Tapestry.5.Building.Web.Applications.Jan.2008.RETAiL.eBOOk-sUppLeX.pdf

    ### Tapestry5:构建Web应用程序 #### 一、Tapestry5概述 Tapestry5是一种先进的、基于Java的Web开发框架,它以其强大的功能、灵活性以及易用性著称。该框架由Howard Lewis Ship创建,并由Apache软件基金会维护。...

    (Tapestry)An infrastructure for Fault-Tolerant Wide-area Location and Routing.ppt

    Tapestry是一个分布式系统基础设施,专门设计用于实现容错性的广域定位和路由。这个系统由Ben Y. Zhao、John Kubiatowicz和Anthony D. Joseph等人在加州大学伯克利分校的计算机科学部开发,旨在应对无处不在计算的...

    tapestry-react:Apache Tapestry和React的集成

    将React( )与Tapestry( )一起使用。 该库提供了将Tapestry与JSX模板结合使用的基本集成。 用法 build.gradle : repositories { jcenter() } dependencies { runtime ' de.eddyson:tapestry-react:0.33.0 '...

Global site tag (gtag.js) - Google Analytics