## 4.11 使用 JSR 330 标准注解
从 Spring 3.0 开始,Spring 提供了对 JSR-330 标准注解(依赖注入)的支持。这些注解可 以和 Spring 注解以相同方式被扫描到。你仅仅需要在类路径下添加相关的 jar 包即可。
> ![](https://box.kancloud.cn/2016-01-25_56a58526bb420.gif)
> 注意
> 如 果 你 使 用 Maven , 那 么 在 标 准 Maven 仓 库([http://repo1.maven.org/maven2/javax/inject/javax.inject/1/](http://repo1.maven.org/maven2/javax/inject/javax.inject/1/))中 javax.inject 的 artifact 是可用的。你仅仅需要在 pom.xml 中添加如下的依赖即可:
```
<dependency>
<groupId>javax.inject</groupId>
<artifactId>javax.inject</artifactId>
<version>1</version>
</dependency>
```
### 4.11.1 使用@Inject 和@Named 进行依赖注入
除了@Autowired,javax.inject.Inject 还可以是下面这样:
```
import javax.inject.Inject;
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
// ...
}
```
至于@Autowired,可以在类级别,字段级别,方法级别和构造方法参数级别使用 @Inject。如果你想对应该被注入的依赖使用限定符名称,你应该按如下方式使用@Named注解:
```
import javax.inject.Inject; import javax.inject.Named; public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(@Named("main") MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
// ...
}
```
### 4.11.2 @Named:@Component 注解的标准等同
除了@Component,javax.inject.Named 还可以是下面这样:
```
import javax.inject.Inject;
import javax.inject.Named;
@Named("movieListener")
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
// ...
}
```
使用@Component 而不指定组件的名称是很常用的方式。@Named 可以被用于相同的 情况:
```
import javax.inject.Inject;
import javax.inject.Named;
@Named
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
// ...
}
```
当使用@Named,当使用 Spring 注解时,可以以相同的方式使用组件扫描:
```
<beans>
<context:component-scan base-package="org.example"/>
</beans>
```
### 4.11.3 标准方法的限制
当使用标准注解时,了解一些不可用,但是很重要的特性是必要的,在下面的表格中给 出:
表 4.6 Spring 注解和标准注解的对比
| Spring | javax.inject.* | javax.inject 限制/注释 |
| --- | --- | --- |
| @Autowired | @Inject | @Inject 没有'required'属性 |
| @Component | @Named |
| @Scope("singleton") | @Singleton | jsr-330 默认范围和 Spring 的 prototype 相似。但是,要保持和 Spring 一般默认值一致,在 Spring 容器中 jsr-330 的 bean 声 明默认是 singleton 的。要使用另外的 范围,你应该使用 Spring 的@Scope 注解。javax.inject 也提供[@Scope](http://download.oracle.com/javaee/6/api/javax/inject/Scope.html) 注解。不过这仅 仅用于创建你自己的注解。 |
| @Qualifier | @Named |
| @Value | - | 不等同 |
| @Required | - | 不等同 |
| @Lazy | - | 不等同 |
- 第一部分 Spring framework 概述
- 第 1 章 Spring Framework 介绍
- 1.1 依赖注入和控制反转
- 1.2 模块
- 1.3 使用方案
- 第二部分 Spring 3 的新特性
- 第 2 章 Spring 3.0 的新特性和增强
- 2.1 Java 5
- 2.2 改进的文档
- 2.3 新的文章和教程
- 2.4 新的模块组织方式和系统构建方式
- 2.5 新特性概述
- 第 3 章 Spring 3.1 的新特性和增强
- 3.1 新特性概述
- 第三部分 核心技术
- 第 4 章 IoC 容器
- 4.1 Spring IoC 容器和 bean 的介绍
- 4.2 容器概述
- 4.3 Bean 概述
- 4.4 依赖
- 4.5 Bean 的范围
- 4.6 自定义 bean 的性质
- 4.7 Bean 定义的继承
- 4.8 容器扩展点
- 4.9 基于注解的容器配置
- 4.10 类路径扫描和管理的组件
- 4.11 使用 JSR 330 标准注解
- 4.12 基于 Java 的容器配置