在Spring容器中为一个bean配置依赖注入有三种方式:
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中。
以上三种注入方式,读者可以根据实际应用场景灵活选择。也希望大家多多支持。