Spring IoC容器:使用JSR 330标准注解

https://docs.spring.io/spring-framework/reference/core/beans/standard-annotations.html

Spring支持JSR-330标准注解(依赖注入)。这些注解的扫描方式与Spring注解相同。要使用它们,你需要在类路径中包含相关的jar包。

如果你使用Maven,jakarta.inject工件在标准的Maven仓库中可用(https://repo.maven.apache.org/maven2/jakarta/inject/jakarta.inject-api/2.0.0/)。你可以将以下依赖项添加到你的pom.xml文件中:

<dependency>
	<groupId>jakarta.inject</groupId>
	<artifactId>jakarta.inject-api</artifactId>
	<version>2.0.0</version>
</dependency>

使用@Inject和@Named进行依赖注入

你可以使用@jakarta.inject.Inject来替代@Autowired,如下所示:

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(...);
		// ...
	}
}

@Autowired一样,你可以在字段级别、方法级别和构造函数参数级别使用@Inject。此外,你可以将你的注入点声明为Provider,允许按需访问短期作用域的bean或者通过Provider.get()调用延迟访问其它bean。下面的例子提供了前面例子的一个变体:

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(...);
		// ...
	}
}

如果你想要使用一个限定名称来指定应该注入的依赖项,你应该使用@Named注解,如下例所示:

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;
	}

	// ...
}

@Autowired一样,@Inject也可以与java.util.Optional@Nullable一起使用。这在这里甚至更加适用,因为@Inject没有required属性。下面的例子对展示了如何使用@Inject@Nullable

public class SimpleMovieLister {

	@Inject
	public void setMovieFinder(Optional<MovieFinder> movieFinder) {
		// ...
	}
}
public class SimpleMovieLister {

	@Inject
	public void setMovieFinder(@Nullable MovieFinder movieFinder) {
		// ...
	}
}

@Named和@ManagedBean:与@Component注解的标准等效项

你可以使用@jakarta.inject.Namedjakarta.annotation.ManagedBean来替代@Component,如下例所示:

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;
	}

	// ...
}

不指定组件名称而使用@Component是非常常见的。@Named也可以以类似的方式使用,如下例所示:

import jakarta.inject.Inject;
import jakarta.inject.Named;

@Named
public class SimpleMovieLister {

	private MovieFinder movieFinder;

	@Inject
	public void setMovieFinder(MovieFinder movieFinder) {
		this.movieFinder = movieFinder;
	}

	// ...
}

当你使用@Named@ManagedBean时,你可以像使用Spring注解一样使用组件扫描,如下例所示:

@Configuration
@ComponentScan(basePackages = "org.example")
public class AppConfig  {
	// ...
}

@Component相比,JSR-330的@Named和JSR-250的@ManagedBean注解不可组合。你应该使用Spring的原型模型来构建自定义组件注解。

JSR-330标准注解的局限性

当你使用标准注解时,你应该知道一些重要功能是不可用的,如下表所示:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值