目录
2.@Named与@ManagedBean:与@Component等价的注解
使用JSR 330 标准注解
从Spring 3.0开始,Spring开始支持JSR-330标准注解。
Spring框架会使用与扫描Spring注解相同的方式,扫描这些注解。
只需要将相关jar包放入classpath即可使用这些注解。
<dependency>
<groupId>javax.inject</groupId>
<artifactId>javax.inject</artifactId>
<version>1</version>
</dependency>
note:maven引入依赖。
1.通过@Inject与@Named进行依赖注入
import javax.inject.Inject;
public class Example {
private Foo foo;
@Inject
public void setFoo(Foo foo) {
this.foo = foo;
}
}
note:使用@Inject注解进行byType的依赖注入。
ps:@Inject注解可以用于域层次、方法层次与构造器参数层次。
import javax.inject.Inject;
import javax.inject.Provider;
public class Example {
private Provider<Foo> foo;
@Inject
public void setFoo(Provider<Foo> foo) {
this.foo = foo;
}
public void process() {
Foo f = foo.get();
}
}
note:使用Provider怠惰访问其他beans或访问shorter范围bean。
import javax.inject.Inject;
import javax.inject.Named;
public class Example {
private Foo foo;
@Inject
public void setFoo(@Named("primary")Foo foo) {
this.foo = foo;
}
}
note:使用注入点的qualifier名称选择注入的依赖,即将qualifier为primary的Foo类型bean注入foo。
public class Example {
@Inject
private Optional<Foo> foo;
}
public class Example {
@Inject
public void setFoo(@Nullable Foo foo) {
...
}
}
note:使用java.util.Optional与@Nullable使得注入点不一定必需被注入成功,即如果容器中找不到合适的bean,注入null。
2.@Named与@ManagedBean:与@Component等价的注解
import javax.inject.Inject;
import javax.inject.Named;
@Named("movieListener") // @ManagedBean("movieListener") could be used as well
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
// ...
}
note:使用@Named替换@Component。
ps:@ManagedBean的用法与@Named用法相同。
ps:与@Component相同,@Named可以省略属性。
ps:@Named与@ManagedBean注解的组件,都可以通过@ComponenScan扫描将bean定义放入容器。
ps:@Named与@ManagedBean无法用于组装自定义的注解。
3.JSR-330标准注解的局限