Spring的依赖注入

    科技2022-09-02  95

    Spring的依赖注入

    2020.10.05

    By ljm

    1.什么是依赖注入?

    依赖注入是spring框架中解耦的一种策略,称为DI或IOC(控制反转),主要有set方式(提供set和get方法)和constractor(构造方法)方式,它使得类与类之间以配置文件的形式组织在一起,而不是硬编码的方式。

    这是我在百度中搜到的答案,似乎没有那么通俗易懂。那么,到底什么是Spring的依赖注入呢?

    我们回想刚开始学习Java的时候,当我们学到类时,我们知道,类中有属性和方法。再学深一点,我们知道一个类也可以当做另一个类的属性。

    当我们开始学习Spring时,我们知道了将类交给Spring容器管理。其实这时候我们就已经知道什么是依赖注入了。在我们将一个类交给Spring容器管理时,将它附属的属性类也配置给这个类,一并交给Spring容器来管理。这就是我们所说的依赖注入了。当然,还可以注入其他普通的数据类型,这里我只做对象类型的注入。

    2.依赖注入的两种方式

    知道了什么是依赖注入后,我们要知道如何进行依赖注入(我就以Service层注入Dao层作为例子展开说明):

    set方法注入

    这个方法需要在这个Service中,写入Set方法:

    public class UserServiceImpl implements UserService { private UserDaoImpl userDaoImpl; public void setUserDaoImpl(UserDaoImpl userDaoImpl){ this.userDaoImpl=userDaoImpl; } @Override public void savaService() { userDaoImpl.save(); System.out.println("调用服务层实现类!"); } }

    接下来,我们使用配置文件将UserDaoImpl注入UserService

    <bean id="userDao" class="com.dao.impl.UserDaoImpl"></bean> <bean id="userService" class="com.service.impl.UserServiceImpl"> <property name="UserDaoImpl" ref="userDao"></property> </bean>

    这时,我们发现程序已经可以成功运行了。

    还有一个是set方法的简洁版,那就是P命名空间注入,使用方法如下:

    首先引入P命名空间:

    xmlns:p="http://www.springframework.org/schema/p"

    其次在进行注入:

    <bean id="userDao" class="com.dao.impl.UserDaoImpl"></bean> <bean id="userService" class="com.service.impl.UserServiceImpl" p:userDaoImpl-ref="userDao"/>

    构造方法注入:

    这里我们使用构造方法,将UserDaoImpl注入UserService,前提首先是有一个构造方法:

    public UserServiceImpl(UserDaoImpl userDaoImpl) { this.userDaoImpl = userDaoImpl; }

    但在我们创建了有参构造方法时,我们一定要保证同时还存在无参构造方法(详情见),因为我们的配置文件是依据无参构造方法来创建我们这个类的。所以无参构造方法一定不能少。

    public UserServiceImpl(){}

    有了方法我们来编写配置文件:

    <bean id="userDao" class="com.dao.impl.UserDaoImpl"></bean> <bean id="userService" class="com.service.impl.UserServiceImpl"> <constructor-arg name="userDaoImpl" ref="userDao"></constructor-arg> </bean>

    其中:constructor-arg标签中,name表示调用构造函数时的参数名,ref表示Spring容器中属性类的唯一标识。

    这样我们也可以完成我们的依赖注入。

    Processed: 0.009, SQL: 9