根据属性配置bean
上个博客使用的例子HelloWorld就是用的属性创建的bean
创建spring项目之HelloWorld
这种方式能够将属性值注入关键是相应的属性必须有set方法,否则注入失败
根据构造函数配置bean
新建一个Person类
package com.imooc.spring;
public class Person {
private String name;
private int age;
private double salary;
public Person(String name, int age) {
super();
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + ", salary=" + salary
+ "]";
}
}
这个类中有三个属性,一个构造方法,构造方法只初始化其中两个参数
- 在配置文件中配置bean
<!-- 通过构造器来配置bean的属性(两种写法) -->
<bean id="person1" class="com.imooc.spring.Person">
<constructor-arg value="tom"></constructor-arg>
<!-- <constructor-arg value="20"></constructor-arg> -->
<constructor-arg>
<value>20</value>
</constructor-arg>
</bean>
- 测试类
public static void main(String[] args) {
ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml");
//通过getBean()来获取实例,传入参数可以是bean的id,也可以是bean的类型
//如果传入参数是bean的类型,必须确保只配置了一个Person类型的bean
//Person person = ctx.getBean(Person.class);
Person p1 = (Person) ctx.getBean("person1");
System.out.println(p1);
}
- 控制台打印结果
- 到目前为止都很顺利。现在我们再加入一个构造函数,参数个数还是两个,但是参数类型并不是原来那两个
package com.imooc.spring;
public class Person {
private String name;
private int age;
private double salary;
public Person(String name, int age) {
super();
this.name = name;
this.age = age;
}
public Person(String name, double salary) {
super();
this.name = name;
this.salary = salary;
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + ", salary=" + salary
+ "]";
}
}
- 在配置文件中再配置一个bean
<!-- 通过构造器来配置bean的属性(两种写法) -->
<bean id="person1" class="com.imooc.spring.Person">
<constructor-arg value="tom"></constructor-arg>
<constructor-arg value="20"></constructor-arg>
</bean>
<bean id="person2" class="com.imooc.spring.Person">
<constructor-arg value="jack"></constructor-arg>
<constructor-arg value="4000"></constructor-arg>
</bean>
使用构造函数配置属性值是根据顺序对应的,现在由两个构造函数,我们配置了两个bean,想第一个使用第一个配置函数,第二个使用第二个配置函数。但是上面这样真的能如愿以偿吗?
- 测试
Person p1 = (Person) ctx.getBean("person1");
System.out.println(p1);
Person p2 = (Person) ctx.getBean("person2");
System.out.println(p2);
- 结果
从结果可以看到,无论是第一个bean还是第二个,都调用了第一个构造方法。
解决方法:
- 根据type确定入参
<!-- 使用type来确定入参的类型 -->
<bean id="person2" class="com.imooc.spring.Person">
<constructor-arg value="jack" type="java.lang.String"></constructor-arg>
<constructor-arg value="4000" type="double"></constructor-arg>
</bean>
- 根据name,index确定入参
<!-- 通过构造器来配置bean的属性 -->
<bean id="person1" class="com.imooc.spring.Person">
<constructor-arg value="tom" index="0"></constructor-arg>
<constructor-arg value="20" index="1"></constructor-arg>
</bean>
<bean id="person2" class="com.imooc.spring.Person">
<constructor-arg value="jack" type="java.lang.String"></constructor-arg>
<constructor-arg value="4000" name="salary"></constructor-arg>
</bean>
name是属性名,index是构造方法参数的顺序。同时,三者可以混合在一起使用。
有些人可能觉得使用使用name是最好的,但是有时属性有很多个,每个都给他指定name会增加工作量,因此应该随机应变,看情况使用。