@Inject 注解可以出现在三种类成员之前,表示该成员需要注入依赖项。按运行时的处理顺序这三种成员类型是:
(1)构造方法
(2)方法
(3)属性
在构造方法上使用 @Inject 时,其参数在运行时由配置好的IoC容器提供。比如,在下面的代码中,运行时调用MurmurMessage类的构造方法时,IoC 容器会注入其参数 Header 和Content 对象。
@Inject public MurmurMessage(Header header, Content content) { this.headr = header; this.content = content; }规范中规定向构造方法注入的参数数量是0个或多个,所以在不含参数的构造方法上使用 @Inject 注解也是合法的。
也可以用@Inject注解方法,与构造方法一样,运行时可注入的参数数量为0个或多个。但使用参数注入的方法不能声明为抽象方法也不能声明其自身的类型参数。下面这段代码在set方法前使用@Inject,这是注入可选属性的常用技术。
@Inject public void setContent(Content concent) { this.content = content; }向方法中注入参数的技术对于服务类方法来说非常有用,其所需的资源可以作为参数注入,比如向查询数据的服务方法中注入数据访问对象(Dao)。
也可以直接在属性上注入(只要它们不是final),虽然这样做简单直接,但是不提倡这样做,因为这样做会让单元测试更加困难。直接注入的语法也很简单。
public class MurmurMessager { @Inject private MurmurMessage murmurMessage; ... }