导读 | 平常的java开发中,程序员在某个类中需要依赖其它类的方法,则通常是new一个依赖类再调用类实例的方法,这种开发存在的问题是new的类实例不好统一管理,spring提出了依赖注入的思想,即依赖类不由程序员实例化,而是通过spring容器帮我们new指定实例并且将实例注入到需要该对象的类中。 |
依赖注入的另一种说法是“控制反转”,通俗的理解是:平常我们new一个实例,这个实例的控制权是我们程序员,而控制反转是指new实例工作不由我们程序员来做而是交给spring容器来做。Spring通过DI(依赖注入)实现IOC(控制反转),常用的注入方式主要有三种:构造方法注入,set方法参数注入,接口注入。
基于@Autowired的自动装配,默认是根据类型注入,可以用于构造器、接口、方法注入,使用方式如下:
@Autowired 构造方法、方法、接口
@Autowired默认是根据参数类型进行自动装配,且必须有一个Bean候选者注入默认required=true,如果允许出现0个Bean候选者需要设置属性“required=false”,“required”属性含义和@Required一样,只是@Required只适用于基于XML配置的setter注入方式,只能打在setting方法上。
通过将@Autowired注解放在构造器上来完成构造器注入,默认构造器参数通过类型自动装配,如下所示:
public class Test1 { private MessageInterface message; @Autowired //构造器注入 private Test1(MessageInterface message) { this.message = message; } //省略getter和setter }
通过将@Autowired注解放在构造器上来完成接口注入。
public class Test2 { @Autowired //接口注入 private MessageInterface messageInterface; //省略getter和setter }
通过将@Autowired注解放在方法上来完成方法参数注入。
public class Test3 { private MessageInterface message; @Autowired //setter方法注入 public void setMessage(MessageInterface message) { this.message = message; } public String getMessage() { return message; } } public class Test4 { private MessageInterface message; // private Listlist; @Autowired(required = true) //任意一个或多个参数方法注入 private void initMessage(MessageInterface message, ArrayList list) { this.message = message; this.list = list; } //省略getter和setter }
原文来自:
本文地址://gulass.cn/dependency-injection-methods.html编辑:薛鹏旭,审核员:逄增宝
Linux大全:
Linux系统大全: