springboot注入集合的方式,spring注入bean的三种方式
目录
地图注射列表注射设置注射数组注射应用你好,我是九头蛇。Spring作为项目中不可或缺的底层框架,提供了bean管理最基本的功能。相信大家对豆注射都不陌生,但是有几种集合注射的方法不常用,有些同学可能不太了解。今天,我们将通过例子来看看它的用法。
首先,声明一个接口:
公共接口UserDao { String getName();}然后定义两个类分别实现这个接口,通过@Component注释将bean放入spring容器:
@Componentpublic类UserDaoA实现UserDao { @ Override public String getName(){ return Hydra ;}} @组件公共类Userdaob实现Userdao { @ Override Public String GetName(){ return #微信官方账号:码农可以参考;}}准备工作完成后,我们来看看几种不同类型的集合注入方式。
00-1010我们先来看一下Map类型的注入,直接在服务中注入一个Map,其中key是字符串类型,value是上面定义的接口类型。
@ Service @ AllArgsConstructorpublic class UserMapService { final MapString,UserDao userDaoMappublic MapString,UserDao getDaos(){ return userDaoMap;}}通过接口测试,检查此地图中的内容:
可以看到,Map中的值是实现接口的实例对象,键是beanName,可以通过@Component的value属性定制。
修改UserDaoA以指定名称:
@ component (value= hydra )公共类userdaoa实现userdao {.}如您所见,key的值已经更改:
Map注入
在服务中,这一次,接口的泛型类型UserDao被注入到列表中。@ Service @ AllArgsConstructorpublic class UserListService { private final list userdao userdao lists;public list userdao getDaos(){ return userDaoLists;}}测试这个方法和检查列表的内容是我们放入容器的两个bean:
我们知道List是一个有序的数据结构,那么如果要修改bean在List中的排序应该怎么做呢?
很简单。修改注入到spring容器中的两个bean,向它们添加@Order注释并指定加载顺序。数字越小,优先级越高。
@Component@Order(1)公共类UserDaoA实现UserDao
{……}
@Component@Order(-1)public class UserDaoB implements UserDao {……}修改完成后,再进行测试,可以看到
bean
的顺序发生了改变:
Set注入
同样,也可以使用无序的Set
注入bean
,泛型指定为接口类型。
@Service@AllArgsConstructorpublic class UserSetService { private final Set<UserDao> userDaoSet; public Set<UserDao> getDaos(){ return userDaoSet; }}查看
Set
中的元素,和List
相同,只不过顺序变为无序,不会因为@Order
注解的值而改变:
数组注入
最后,我们再来看一下数组注入的方式:
@Service@AllArgsConstructorpublic class UserArrayService { private final UserDao[] userDaoArray; public UserDao[] getDaos(){ return userDaoArray; }}查看数组中的元素:
并且,和List
比较类似的,数组中bean
的排序会受到@Order
注解数值的影响,有兴趣的同学可以自己尝试一下。
应用
了解了这几种注入方式后,再简单提一下它的使用场景。例如,我们可以用Map
注入实现策略模式,来替换代码中繁杂的if/else
判断。例如,原始的代码中判断逻辑可能是这样的:
public String choice(String name){ if (name.equals("auth")){ return "Hydra"; }else if (name.equals("official")){ return "#公众号:码农参上"; } return null;}使用策略模式进行改造,首先修改
beanName
:
@Component(value = "auth")public class UserDaoA implements UserDao { @Override public String getName() { return "Hydra"; }}
@Component(value = "official")public class UserDaoB implements UserDao { @Override public String getName() { return "#公众号:码农参上"; }}再修改
Servie
中的方法,一行代码即可实现原有的if/else
判断:
@Service@AllArgsConstructorpublic class TestService { final Map<String, UserDao> userDaoMap; public String choice2(String name){ return userDaoMap.get(name).getName(); };}可能在这个例子中,这种写法的优点体现的不十分明显,但是当你有一个非常长的
if/else
判断时,这种模式能使你的代码看上去简洁很多,并且符合代码按照功能拆分的原则。 同理,如果你已经通过@Order
注解定义好了bean
的加载顺序,也可以将它理解为bean
的优先级,例如我想要调用优先级最高的符合类型的bean
的方法,那么完全可以这样写:
@Service@AllArgsConstructorpublic class TestService { final List<UserDao> userDaoLists; public String choiceFirst(){ return userDaoLists.get(0).getName(); };}通过上面两个简单的例子可以看到,集合注入的方式使用起来非常灵活,我们可以在实际使用中,结合各种设计模式,写出实用而优雅的代码。
以上就是Spring中bean集合注入的方法详解的详细内容,更多关于Spring集合注入的资料请关注盛行IT其它相关文章!
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。