此版本仍在开发中,尚未被视为稳定版本。对于最新的稳定版本,请使用 Spring Framework 6.2.0! |
使用 JSR 330 标准注释
Spring 提供对 JSR-330 标准注释(依赖注入)的支持。那些 Comments 的扫描方式与 Spring Comments 相同。要使用它们,您需要 以将相关的 jar 放在 Classpath 中。
如果您使用 Maven,则工件在标准 Maven 中可用
存储库 ( https://repo.maven.apache.org/maven2/jakarta/inject/jakarta.inject-api/2.0.0/)。
您可以将以下依赖项添加到文件pom.xml:
|
使用 和 的依赖项注入@Inject
@Named
您可以按如下方式使用 ,而不是 :@Autowired
@jakarta.inject.Inject
-
Java
-
Kotlin
import jakarta.inject.Inject;
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
public void listMovies() {
this.movieFinder.findMovies(...);
// ...
}
}
import jakarta.inject.Inject
class SimpleMovieLister {
@Inject
lateinit var movieFinder: MovieFinder
fun listMovies() {
movieFinder.findMovies(...)
// ...
}
}
与 一样,您可以在字段级别、方法级别使用
和 constructor-argument 级别。此外,您可以将注入点声明为 ,允许按需访问范围较短的 bean 或延迟访问
其他 bean 通过调用。以下示例提供了
前面的示例:@Autowired
@Inject
Provider
Provider.get()
-
Java
-
Kotlin
import jakarta.inject.Inject;
import jakarta.inject.Provider;
public class SimpleMovieLister {
private Provider<MovieFinder> movieFinder;
@Inject
public void setMovieFinder(Provider<MovieFinder> movieFinder) {
this.movieFinder = movieFinder;
}
public void listMovies() {
this.movieFinder.get().findMovies(...);
// ...
}
}
import jakarta.inject.Inject
class SimpleMovieLister {
@Inject
lateinit var movieFinder: Provider<MovieFinder>
fun listMovies() {
movieFinder.get().findMovies(...)
// ...
}
}
如果您想为应该注入的依赖项使用限定名称,
您应该使用注释,如下例所示:@Named
-
Java
-
Kotlin
import jakarta.inject.Inject;
import jakarta.inject.Named;
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(@Named("main") MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
// ...
}
import jakarta.inject.Inject
import jakarta.inject.Named
class SimpleMovieLister {
private lateinit var movieFinder: MovieFinder
@Inject
fun setMovieFinder(@Named("main") movieFinder: MovieFinder) {
this.movieFinder = movieFinder
}
// ...
}
与 一样,也可以与 或 一起使用。这在这里更适用,因为没有
一个属性。以下一对示例演示如何使用 and :@Autowired
@Inject
java.util.Optional
@Nullable
@Inject
required
@Inject
@Nullable
public class SimpleMovieLister {
@Inject
public void setMovieFinder(Optional<MovieFinder> movieFinder) {
// ...
}
}
-
Java
-
Kotlin
public class SimpleMovieLister {
@Inject
public void setMovieFinder(@Nullable MovieFinder movieFinder) {
// ...
}
}
class SimpleMovieLister {
@Inject
var movieFinder: MovieFinder? = null
}
@Named
和 : 注释的标准等效项@ManagedBean
@Component
您可以使用 或 ,而不是 ,
如下例所示:@Component
@jakarta.inject.Named
jakarta.annotation.ManagedBean
-
Java
-
Kotlin
import jakarta.inject.Inject;
import jakarta.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;
}
// ...
}
import jakarta.inject.Inject
import jakarta.inject.Named
@Named("movieListener") // @ManagedBean("movieListener") could be used as well
class SimpleMovieLister {
@Inject
lateinit var movieFinder: MovieFinder
// ...
}
在不指定组件名称的情况下使用是很常见的。 可以以类似的方式使用,如下例所示:@Component
@Named
-
Java
-
Kotlin
import jakarta.inject.Inject;
import jakarta.inject.Named;
@Named
public class SimpleMovieLister {
private MovieFinder movieFinder;
@Inject
public void setMovieFinder(MovieFinder movieFinder) {
this.movieFinder = movieFinder;
}
// ...
}
import jakarta.inject.Inject
import jakarta.inject.Named
@Named
class SimpleMovieLister {
@Inject
lateinit var movieFinder: MovieFinder
// ...
}
当您使用 或 时,您可以在
与使用 Spring 注释时的方式完全相同,如下例所示:@Named
@ManagedBean
-
Java
-
Kotlin
@Configuration
@ComponentScan(basePackages = "org.example")
public class AppConfig {
// ...
}
@Configuration
@ComponentScan(basePackages = ["org.example"])
class AppConfig {
// ...
}
与 相反,JSR-330 和 JSR-250 注释是不可组合的。您应该使用 Spring 的 stereotype 模型来构建
自定义组件注释。@Component @Named @ManagedBean |
JSR-330 标准注释的限制
当您使用标准注释时,您应该知道一些重要的 功能不可用,如下表所示:
Spring | jakarta.inject 的 | jakarta.inject 限制 / 评论 |
---|---|---|
@Autowired |
@Inject |
|
@Component |
@Named / @ManagedBean |
JSR-330 不提供可组合模型,只提供一种标识命名组件的方法。 |
@Scope(“单例”) |
@Singleton |
JSR-330 的默认范围类似于 Spring 的 .但是,为了保持它
与 Spring 的一般默认值一致,在 Spring 中声明的 JSR-330 bean
container 默认为 a。为了使用除 之外的作用域 ,
你应该使用 Spring 的 Comments。 还提供了一个注释:但是,这个只是为了使用
用于创建自定义注释。 |
@Qualifier |
@Qualifier / @Named |
|
@Value |
- |
无等效项 |
@Lazy |
- |
无等效项 |
对象工厂 |
供应商 |
|