构造方法注入
无参构造
<bean id="hello" class="HelloSpring">
<property name="name" value="helloworld"></property>
</bean>
有参构造
<!--第一种下标构建-->
<bean id="user1" class="IOC_User">
<constructor-arg index="0" value="msf"></constructor-arg>
<constructor-arg index="1" value="21"></constructor-arg>
</bean>
<!--第二种参数类型构建-->
<bean id="user2" class="IOC_User">
<constructor-arg type="java.lang.String" value="msf"></constructor-arg>
<constructor-arg type="int" value="21"></constructor-arg>
</bean>
<!--第三种参数名称构建-->
<bean id="user3" class="IOC_User">
<constructor-arg name="name" value="msf"></constructor-arg>
<constructor-arg name="age" value="21"></constructor-arg>
</bean>
<!--参数类型是其他有参对象时-->
<bean id="userCon" class="IOCUserCon">
<constructor-arg name="user" ref="user3"></constructor-arg>
</bean>
setter注入
如果属性是集合框架,可以使用容器指定的框架标签进行注入,properties资源文件也有特定的标签,如下
<bean id="student" class="IOCStudent">
<property name="name" value="msf"></property>
<property name="books" >
<array>
<value>GoF</value>
<value>HTTP</value>
</array>
</property>
<property name="ioc_user" ref="user1"></property>
<property name="card">
<map>
<entry key="jkl" value="qwe"></entry>
<entry key="qew" value="qw"></entry>
</map>
</property>
<property name="hobby">
<list>
<value>123</value>
</list>
</property>
<property name="info">
<props>
<prop key="学号">20191312333</prop>
</props>
</property>
</bean>
bean标签常用属性
自动装配
bean标签的autowire属性,和beans的default-autowire属性可以指定当前bean采用何种自动装配的属性。
no
默认模式不采取任何方式的自动装配
byName
按照类声明的实例变量名称进行自动绑定
byType
按照类声明的实例类型进行自动绑定,如果有多个同类型bean则会报错
constructor
上面两种是针对property的自动绑定,constructor则是针对构造方法参数类型进行的自动绑定,寻找方式是byType,会自动绑定参数最多的构造方法(大概,不过可以在被绑定的构造方法旁边看到spring的豌豆标志)。
autodetect
这种模式是byType和constructor的结合体,如果对象有无参构造方法则优先考虑byType,否则会先用constructor模式,如果之后有未绑定的字段则会byType自动绑定。
优缺点和注意事项
自动绑定只适用于原生类型,String类型和Classes类型以外的类型
作用域
bean的scope属性可以规定该实例的生命周期
基本的两种属性值
singleton
类似于单例模式,IOC容器的生命周期中只存在一个实例,所有对象的引用都共享这个实例,寿命几乎和IOC容器一致(取决于lazy-init)
注意这个不同于单例模式,这个是标记该IOC容器中只有一个实例对象,而单例模式则是一个Classloader中只存在一个这种类型的实例
prototype
容器在接收到请求后会返回给请求方一个新的实例,之后这个实例的生命周期管理交给请求方
另外三种request session 和global session则是web中应用到的,以后再补充
继承
使用parent标签注明这个bean继承自哪个bean,只需要将特定的属性进行更改,而不需要全部重新定义一遍。
同时parent标签和abstract配合可以实现定义模板化bean的功能,设置abstract属性值为true的bean在容器初始化的时候不会实例化,因此可以不指定class属性。这样可以将重复多次的属性配置抽象出来。