在写接口实现时,有时会有多个实现类。这篇文章介绍在调用时通过传入字符串来指定具体的实现类。
一.接口与实现类:
// 接口 public interface ServiceInterface { public void method(); } // 具体两个实现类 @Service("aService") public class AServiceImpl implements ServiceInterface { @Override public void method() { System.out.println("the impl is A"); } @Override public String toString() { return "A"; } } @Service("bService") public class BServiceImpl implements ServiceInterface { @Override public void method() { System.out.println("the impl is B"); } @Override public String toString() { return "B"; } }
在实现类中重写了toString() 方法,可以自定义字符串,当调用时传入指定的字符串就能获取到相应的bean。
二.register书写:
@Service("register") public class Register implements InitializingBean, ApplicationContextAware { private Map<String, ServiceInterface> serviceImplMap = new HashMap<>(); private ApplicationContext applicationContext; // 获取spring的上下文 @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { this.applicationContext = applicationContext; } // 获取接口实现类的所有bean,并按自己定的规则放入map中 @Override public void afterPropertiesSet() throws Exception { Map<String, ServiceInterface> beanMap = applicationContext.getBeansOfType(ServiceInterface.class); // 以下代码是将bean按照自己定的规则放入map中,这里我的规则是key:service.toString();value:bean // 调用时,参数传入service.toString()的具体字符串就能获取到相应的bean // 此处也可以不做以下的操作,直接使用beanMap,在调用时,传入bean的名称 for (ServiceInterface serviceImpl : beanMap.values()) { serviceImplMap.put(serviceImpl.toString(), serviceImpl); } } public ServiceInterface getServiceImpl(String name) { return serviceImplMap.get(name); } }
三.测试类:
@Resource Register register; @Test public void testService() { ServiceInterface service = register.getServiceImpl("A"); service.method(); ServiceInterface service2 = register.getServiceImpl("B"); service2.method(); }
运行结果,如图:
备注:
在spring加载后,获取applicationContext的方法:
实现ApplicationContextAware接口的Bean,在Bean加载的过程中可以获取到Spring的ApplicationContext,这个尤其重要,ApplicationContext是Spring应用上下文,从ApplicationContext中可以获取包括任意的Bean在内的大量Spring容器内容和信息
@Component("informerRegistry") public final class InformerRegistry implements ApplicationContextAware{ private ApplicationContext applicationContext; @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { this.applicationContext = applicationContext; } }
关于spring常用bean扩展接口可参考:http://www.cnblogs.com/xrq730/p/5721366.html
注意:
使用以下方法获取spring上下文时,会启动spring。多次写以下方法,就会启动多个spring容器
ApplicationContext ctx = new ClassPathXmlApplicationContext("classpath:META-INF/spring/*.xml");
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。