Spring的bean可以通过设置parent属性指定他的父bean
必要条件:
- 子bean必须与父bean保持兼容,也就是说子bean中必须有父bean定义的所有属性。
- 父bean必须是抽象bean或者定义lazy-init=true也就是不让bean工厂实例化该bean,或者设置bean的abstract属性为true
继承存在的两种情况:
1、如果**父bean有class属性**,而子bean没有,那么子bean的class就和父bean相同 例如:
<!-- 父bean -->
<bean id="testProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"
abstract="true"> //********(1)
<property name="transactionManager" >
<ref bean="transactionManager"/>
</property>
<property name="proxyTargetClass" value="true" />
<property name="transactionAttributes">
<props>
<prop key="*insert*">PROPAGATION_REQUIRED</prop>
<prop key="*select*">PROPAGATION_REQUIRED,readOnly</prop>
</props>
</property>
</bean>
<!-- 子bean -->
<bean id="test" parent="testProxy">
<property name="target">
<ref bean="testit"/> //******(2)
</property>
</bean>
为了解决代码的低重用,我在testProxy里没有定义target属性,targe属性的定义放在了外面一个bean里,这个bean继承了testProxy(parent),这样bean中parent中已注入的属性不需要再注入,在子bean中只需要注入还没有注入的属性即可!注意:也只能注入
TransactionProxyFactoryBean
中有的属性,重复了覆盖,但是不能注入其他任何属性
2、如果父bean没有定义class属性,子bean必须定义class属性,这时候父bean实际上仅仅是一个纯模版或抽象bean,仅仅充当子定义的父定义。
<beans>
<bean id="parentBean">
<property name="name"><value>parent</value></property>
<property name="age"><value>1</value></property>
</bean>
<bean id="sunBean" class="SunBean"
parent="parentBean" init-method="initialize">
<property name="name"><value>override</value></property>
</bean>
若要尝试单独使用这样的parent bean(比如将它作为其他bean的ref属性而引用,或者直接使用这个parent bean的id调用getBean()方法),将会导致一个错误。这个父bean的功能也就是为了减少配置的书写而采用的,举例如下,如果有n个bean都要配置m个相同的属性,如果不采用父bean概念,将要配置这m个属性n次,采用父bean方式将这共同的m个属性配置在父bean中,而在这n个bean中都增加一个parent属性 指向那个bean就可以。(这里的m个属性也要满足必要条件,都在子bean对应的类中定义)