·······································自动装配········································
Spring IOC 容器可以自动装配 Bean. 需要做的仅仅是在 <bean> 的 autowire 属性里指定自动装配的模式
byType(根据类型自动装配): 若 IOC 容器中有多个与目标 Bean 类型一致的 Bean.
在这种情况下, Spring 将无法判定哪个 Bean 最合适该属性, 所以不能执行自动装配.
byName(根据名称自动装配): 必须将目标 Bean 的名称和属性名设置的完全相同.
constructor(通过构造器自动装配): 当 Bean 中存在多个构造器时, 此种自动装配方式将会很复杂. 不推荐使用
缺点:
在 Bean 配置文件里设置 autowire 属性进行自动装配将会装配 Bean 的所有属性. 然而, 若只希望装配个别属性时,
autowire 属性就不够灵活了.
autowire 属性要么根据类型自动装配, 要么根据名称自动装配, 不能两者兼而有之.
一般情况下,在实际的项目中很少使用自动装配功能,因为和自动装配功能所带来的好处比起来,明确清晰的配置文档更有说服力一些
··········································code············································
( private address address; private car car;)
<bean id= "address" class = "autowire.address" p:city="harbin" p:street="xuefu"></bean>
<bean id = "car" class = "autowire.car" p:price="100" p:maxspeed="123"></bean>
<!-- 可以使用autowire属性指定装配的方式
byname是根据bean的名字和当前bean的setter风格的属性名进行自动装配
若无配对则为null
bytype根据属性类型进行自动装配 要求同类型的bean只有一个
-->
<bean id = "person" class = "autowire.person" autowire="byName" p:name="dada"></bean>
·································继承&&依赖bean配置·······························
Spring 允许继承 bean 的配置, 被继承的 bean 称为父 bean. 继承这个父 Bean 的 Bean 称为子 Bean,
子 Bean 从父 Bean 中继承配置, 包括 Bean 的属性配置
子 Bean 也可以覆盖从父 Bean 继承过来的配置
父 Bean 可以作为配置模板, 也可以作为 Bean 实例. 若只想把父 Bean 作为模板, 可以设置 <bean> 的abstract 属性为 true,
这样 Spring 将不会实例化这个Bean
并不是 <bean> 元素里的所有属性都会被继承. 比如: autowire, abstract 等.
也可以忽略父 Bean 的 class 属性, 让子 Bean 指定自己的类, 而共享相同的属性配置. 但此时 abstract 必须设为 true
Spring 允许用户通过 depends-on 属性设定 Bean 前置依赖的Bean,前置依赖的 Bean 会在本 Bean 实例化之前创建好
如果前置依赖于多个 Bean,则可以通过逗号,空格或的方式配置 Bean 的名称
···········································code···········································
<!-- 可实例化父类,在mian中可以创建对象 -->
<bean id = "address" class= "relation.address" p:city="harbin" p:street="xuefu"></bean>
<!-- 抽象父类,不可实例化 -->
<bean id = "address2" abstract="true" class= "relation.address" p:city="harbin" p:street="xuefu"></bean>
<!-- 当某一个bean的class属性没有指定,则该类必须是一个抽象类 即模板 -->
<bean id = "address3" abstract="true" p:city="harbin" p:street="xuefu"></bean>
<!-- bean 配置的继承 使用bean的parent的属性继承那个bean的配置 -->
<bean id = "address4" parent="address" p:street="nangang"></bean>
<!-- 用bean的depend-on属性设置依赖, 当配置person时,一定会有关联的car,可用逗号、空格指定多个bean -->
<bean id = "car" class = "relation.car" p:price="10" p:maxspeed="10"></bean>
<bean id = "person" class = "relation.person" p:name="adad" depends-on="car" p:address-ref="address4"></bean>
······································bean的作用域····································
在 Spring 中, 可以在 <bean> 元素的 scope 属性里设置 Bean 的作用域.
默认情况下, Spring 只为每个在 IOC 容器里声明的 Bean 创建唯一一个实例, 整个 IOC 容器范围内都能共享该实例:
所有后续的 getBean() 调用和 Bean 引用都将返回这个唯一的 Bean 实例.该作用域被称为 singleton, 它是所有 Bean 的默认作用域.

···········································code·········································
<!-- bean 的作用域 (整个容器的生命周期中)
prototype每次返回的时新的实例,容器初始化时不创建实例,原型的
singleton每次返回的是同一个,容器初始化是创建实例, 默认值
-->
<bean id = "car" class = "scope.car" scope="singleton">
<property name="price" value= "10"></property>
<property name="maxspeed" value = "10"></property>
</bean>
···································使用外部属性文件·································
在配置文件里配置 Bean 时, 有时需要在 Bean 的配置里混入系统部署的细节信息(例如: 文件路径, 数据源配置信息等).
而这些部署细节实际上需要和 Bean 配置相分离
Spring 提供了一个 PropertyPlaceholderConfigurer 的 BeanFactory 后置处理器, 这个处理器允许用户将 Bean 配置的部分
内容外移到属性文件中. 可以在 Bean 配置文件里使用形式为 ${var} 的变量, PropertyPlaceholderConfigurer 从属性文件里
加载属性, 并使用这些属性来替换变量.
Spring 还允许在属性文件中使用 ${propName},以实现属性之间的相互引用。
············································code··········································
<!--
加入context命名空间
导入属性文件
-->
<context:property-placeholder location="classpath:dp.properties"/>
<bean id = "datasource" class = "com.mchange.v2.c3p0.ComboPooledDataSource">
<!-- 使用外部化属性文件的属性 -->
<property name="user" value = "${user}"></property>
<property name="password" value = "${password}"></property>
<property name="driverClass" value ="${driverClass}"></property>
<property name="jdbcUrl" value = "${jdbcUrl}"></property>
</bean>
(外部配置文件.properties)
user=root
password = 1230
driverClass = com.mysql.jdbc.Driver
jdbcUrl = jdbc:mysql:///test