2005-8-13
在如下方面HiveMind優(yōu)于Spring:
* HiveMind強(qiáng)制針對(duì)接口編程;
* HiveMind使用module概念來(lái)分組管理service,利于并行和迭代開(kāi)發(fā);
* HiveMind使用的配置文件格式更清楚簡(jiǎn)明,特別是將接口和實(shí)現(xiàn)統(tǒng)一定義成1個(gè)service,而Spring可能要定義好幾個(gè)bean元素;
* 在增加或移去interceptor時(shí),HiveMind只要修改1行配置文件,而Spring至少要修改兩個(gè)bean元素;
* 在定義interceptor時(shí),HiveMind采用javassist類庫(kù),性能優(yōu)于Spring采用的JDK proxy。
在如下方面Spring優(yōu)于HiveMind:
* Spring的AOP框架較為成熟,編寫(xiě)interceptor的難度較低。
* Spring內(nèi)建和Hibernate的集成,HiveMind尚未內(nèi)建該集成。
* Spring的transaction management支持各種transaction API,如JDBC、JDO、JTA等等。
基于以上發(fā)現(xiàn),建議在下一項(xiàng)目中采用HiveMind。因?yàn)橐呀?jīng)自行開(kāi)發(fā)了HiveMind和Hibernate的集成以及簡(jiǎn)單的transaction management代碼,因而在下一項(xiàng)目中并不特別需要Spring的相應(yīng)功能。不過(guò),當(dāng)前HiveMind是1.0-rc2版,一旦發(fā)布1.0-release版則應(yīng)盡快升級(jí)。
[Spring VS. HiveMind]:
* Service Oriented?
Spring : Yes.
HiveMind : Yes.
* How to define a Service?
Spring :
Define a POJO. (在Spring術(shù)語(yǔ)中稱之為bean,但實(shí)際上是POJO。)
配置文件:<bean id="exampleBean" class="examples.ExampleBean"/>
HiveMind:
Define an interface and core implementation POJO.
配置文件:service-point元素。
Comments:
HiveMind強(qiáng)制針對(duì)接口編程,優(yōu)于Spring。
* 是否提供service的namespace?
Spring:
僅僅使用id屬性來(lái)唯一識(shí)別service。
支持多配置文件。
HiveMind:
提供Module概念用于管理service namespace,類似于java中的package。
支持多個(gè)配置文件。
Comments:
HiveMind略優(yōu)。
* Service Lifecycle?
Spring:
2 Lifecycle models: Singleton, Prototype.
HiveMind:
4 Lifecycle models: Primitive, Singleton, Threaded, Pooled.
Comments:
最常用的就是Singleton模型。雖然HiveMind模型多于Spring,但不構(gòu)成優(yōu)勢(shì)。
* Who manages service?
Spring: BeanFactory or ApplicationContext.
HiveMind: Registry.
* Dependency Injection?
Spring: yes. type-2 and type-3 supported.
HiveMind: yes. type-2 and type-3 supported.
* Service Depenency Injection?
Spring:
使用ref元素。
<property name="beanOne"><ref bean="anotherExampleBean"/></property>
HiveMind:
在配置文件中使用set-service元素。
<set-service service-id="anotherService"/>
Comments:
在更換實(shí)現(xiàn)時(shí),HiveMind因強(qiáng)制針對(duì)接口編程而占有優(yōu)勢(shì)。
* Intializing and finalizing methods?
Spring :
<bean id="exampleInitBean" class="examples.ExampleBean"
init-method="init()"
destroy-method="cleanup()"/>
/>
HiveMind:
<construct class="..." initialize-method="..."/>
不支持finalizing method。
Comments:
Spring略優(yōu)。
* How to configure AOP?
Spring:
<!-- Step 1 : 定義核心實(shí)現(xiàn) -->
<bean id="personTarget" class="com.mycompany.PersonImpl">
<property name="name"><value>Tony</value></property>
<property name="age"><value>51</value></property>
</bean>
<!-- Step 2 : 定義Interpreter -->
<bean id="myAdvisor" class="com.mycompany.MyAdvisor">
<property name="someProperty"><value>Custom string property value</val></property>
</bean>
<bean id="debugInterceptor" class="org.springframework.aop.interceptor.Nop
Interceptor">
</bean>
<!-- Step 3 : 定義接口 -->
<bean id="person"
class="org.springframework.aop.framework.ProxyFactoryBean"
>
<property name="proxyInterfaces"><value>com.mycompany.Person</value></
property>
<property name="target"><ref local="personTarget"/></property>
<!-- Step 4 : 聲明引用 interpreter -->
<property name="interceptorNames">
<list>
<value>myAdvisor</value>
<value>debugInterceptor</value>
</list>
</property>
</bean>
HiveMind:
<!-- 定義接口 -->
<service-point id="Adder" interface="slhynju.doconline.business.Adder">
<!-- 構(gòu)造核心實(shí)現(xiàn) -->
<invoke-factory>
<construct class="slhynju.doconline.business.AdderImpl">
<set-service property="sessionSource" service-id="SessionSource" />
</construct>
</invoke-factory>
<!-- 聲明引用 interpreter -->
<interceptor service-id="hivemind.LoggingInterceptor"/>
<interceptor service-id="TransactionInterceptor"/>
</service-point>
Comments:
Spring將接口和核心實(shí)現(xiàn)分開(kāi)定義成兩個(gè)bean,HiveMind則統(tǒng)一定義成一個(gè)service。
這點(diǎn)上HiveMind優(yōu)于Spring。
Spring的AOP框架較為成熟。HiveMin的Interpreter factory仍需要降低編寫(xiě)難度。
HiveMind采用javassist,性能上優(yōu)于Spring采用JDK proxy。
* How to configure declarative transaction management?
Spring: 采用AOP。
<bean id="petStoreTarget" class="org.springframework.samples.jpetstore.dom
ain.logic.PetStoreImpl">
<property name="accountDao"><ref bean="accountDao"/></property>
<!-- Other dependencies omitted -->
</bean>
<bean id="petStore"
class="org.springframework.transaction.interceptor.TransactionProxyFac
toryBean">
<property name="transactionManager"><ref bean="transactionManager"/></
property>
<property name="target"><ref local="petStoreTarget"/></property>
<property name="transactionAttributes">
<props>
<prop key="insert*">PROPAGATION_REQUIRED</prop>
<prop key="update*">PROPAGATION_REQUIRED</prop>
<prop key="*">PROPAGATION_REQUIRED,readOnly</prop>
</props>
</property>
</bean>
HiveMind: 沒(méi)有內(nèi)建支持。我自行開(kāi)發(fā)了一個(gè)TransactionInterceptor
<interceptor service-id="TransactionInterceptor">
<include method="add*"/>
</interceptor>
Comments:
在Spring中如果需要混合使用TransactionInterceptor和其他Interceptor,需要定義多個(gè)bean。增大了維護(hù)成本。
Spring支持JTA等各種Transaction manager。
HiveMind配置文件更加清楚簡(jiǎn)明。但不沒(méi)有提供JTA集成很致命。