Spring Bean三种注入方式详解

spring容器中为一个bean配置依赖注入有三种方式:

  1.  使用属性的setter方法注入  这是最常用的方式;
  2.  使用构造器注入;
  3.  使用Filed注入(用于注解方式).

Field注入是最常见的一种方式,可以采用 @Autowired 对Bean类的接口进行初始化,代码如下

@ContextConfiguration({"/meta-inf/spring/amazing-base.xml"})
@RunWith(SpringJUnit4ClassRunner.class)
public class SpringInjectionTest {
  @Autowired
  private Cust normalCust;
  
  @Test
  public void testFieldInjection() {
    System.out.println("testFieldInjection begin");
    normalCust.recharge();
    System.out.println("testFieldInjection end");
  }
}

Cust为接口,normalCust为其实现类,通过这种方式,可以通过spring容器初始化normalCust Bean,进而调用recharge()方法

构造器注入主要用于某些类因为某种原因不能作为Bean,只是一个普通类。可以通过类的构造方法传入需要调用的Bean接口。

@ContextConfiguration({"/meta-inf/spring/amazing-base.xml"})
@RunWith(SpringJUnit4ClassRunner.class)
public class SpringInjectionTest {
  @Autowired
  private Cust normalCust;
  
  @Test
  public void testConstructorInjection() {
    System.out.println("testConstructorInjection begin");
    ChargeThread thread = new ChargeThread(normalCust);
    thread.run();
    System.out.println("testConstructorInjection end");
  }
  
}
public class ChargeThread implements Runnable {
  
  private Cust cust;
  
  public ChargeThread(Cust cust) {
    this.cust = cust;
  }

  public void run() {
    cust.recharge();
  }

}

上面的代码通过初始化一个线程,在初始化的时候传入Bean,在线程的类中调用Bean的充值方法。构造器注入特别适合多线程的编程,因为线程不能定义为Bean,否则不仅会因为它是一个单例,而且会被spring容器管理。(当然你可以去定义Bean为原型Bean,能够有多个副本,脱离spring容器的管理),最重要的是我们要用线程池,由线程池来管理线程。

还有一种Setter方法注入,这种方式能用于final类的静态方法,例如有一个充值的Util类,该类是final类,其方法是静态方法

public class SpringInjectionTest {
  @Test
  public void testSetterInjection() {
    System.out.println("testSetterInjection begin");
    String result = RechargeUtil.InstantRecharge();
    System.out.println("testSetterInjection end," + result);
  }

}

@Component
public final class RechargeUtil {
  
  private RechargeUtil() {
    
  }
  
  private static Cust normalCust;
  
  @Autowired
  public void setnormalCust(Cust normalCust) {
    RechargeUtil.normalCust = normalCust;
  }

  public static String InstantRecharge() {
    normalCust.recharge();
    return "InstantRecharge Success!";
  }
}

最后一种方式也成功了将normalCust注入到了RechargeUtil中。

以上三种注入方式,读者可以根据实际应用场景灵活选择。也希望大家多多支持编程小技巧。

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...