springboot注入集合的方式,spring注入bean的三种方式

  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的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: