依赖注入及AOP简述八——混合请求模式

2.3.混合请求模式

上一节讲到了FQCN(全类名)请求模式会带来依赖定义的柔软性较差的问题,因此字符串和全类名混合的模式又应运而生了。比如刚才的Spring中的API方式声明注入点的例子就可以改为使用下面的API:

// Spring的字符串+全类名注入的API

beanfactory injector = new FileSystemApplicationContext("depositConfiguration.xml")

this.bank = (Bank) injector.getBean("bank",Bank.class);

// 请求名为"bank"且类为Bank的依赖


而在Guice中则提供了更为安全、可维护性更高的基于注解模式的混合请求模式,此时标识符不再仅仅是一个字符串,而是一个自定义的Java5注解。例如上一节中举的Setter注入点的例子,可以用下面的方式来实现混合请求依赖:

public class Depositor {

private Bank bank;

// ……

@Inject // bank的Setter注入点

public void setBank(@BankICBC Bank bank) {

// 请求标识符为"@BankICBC"注解并且类为Bank的依赖

// "@BankICBC"注解是一个被绑定到BankICBC.class的自定义注解

this.bank = bank;

}

// ……

}

相关文章

迭代器模式(Iterator)迭代器模式(Iterator)[Cursor]意图...
高性能IO模型浅析服务器端编程经常需要构造高性能的IO模型,...
策略模式(Strategy)策略模式(Strategy)[Policy]意图:定...
访问者模式(Visitor)访问者模式(Visitor)意图:表示一个...
命令模式(Command)命令模式(Command)[Action/Transactio...
生成器模式(Builder)生成器模式(Builder)意图:将一个对...