spring全家桶之springIOC篇 —— (4)、bean的配置

根据属性配置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会增加工作量,因此应该随机应变,看情况使用。

猜你喜欢

转载自blog.csdn.net/abc997995674/article/details/80271462