软件编程
位置:首页>> 软件编程>> java编程>> Spring依赖注入(DI)两种方式的示例详解

Spring依赖注入(DI)两种方式的示例详解

作者:夏志121  发布时间:2021-09-14 12:00:20 

标签:Spring,依赖,注入

一、依赖注入方式

思考:向一个类中传递数据的方式有几种?

  • 普通方法(set方法)

  • 构造方法

思考:依赖注入描述了在容器中建立bean与bean之间依赖关系的过程,如果bean运行需要的是数字或字符串呢?

  • 引用类型

  • 简单类型(基本数据类型与String)

依赖注入方式:

setter注入

  • 简单类型

  • 引用类型

构造器注入

  • 简单类型

  • 引用类型

二、setter注入

引用类型

在bean中定义引用类型属性并提供可访问的set方法

import com.itheima.dao.BookDao;
import com.itheima.service.BookService;

public class BookServiceImpl implements BookService {
   private BookDao bookDao;

public void save() {
       System.out.println("book service save ...");
       bookDao.save();
   }
   public void setBookDao(BookDao bookDao) {
       this.bookDao = bookDao;
   }
}

配置中使用property标签ref属性注入引用类型对象

<!--注入引用类型-->
   <bean id="bookService" class="com.itheima.service.impl.BookServiceImpl">
       <!--property标签:设置注入属性-->
       <!--name属性:设置注入的属性名,实际是set方法对应的名称-->
       <!--ref属性:设置注入引用类型bean的id或name-->
       <property name="bookDao" ref="bookDao"/>
       <property name="userDao" ref="userDao"/>
   </bean>

简单类型

BookDaoImpl实现类:

在bean中定义引用类型属性并提供可访问的set方法

import com.itheima.dao.BookDao;

public class BookDaoImpl implements BookDao {

private String databaseName;
   private int connectionNum;

//setter注入需要提供要注入对象的set方法
   public void setConnectionNum(int connectionNum) {
       this.connectionNum = connectionNum;
   }

//setter注入需要提供要注入对象的set方法
   public void setDatabaseName(String databaseName) {
       this.databaseName = databaseName;
   }

public void save() {
       System.out.println("book dao save ..." + databaseName + "," + connectionNum);
   }
}

applicationContext.xml配置:

配置中使用property属性value注入简单类型对象

<!--注入简单类型-->
   <bean id="bookDao" class="com.itheima.dao.impl.BookDaoImpl">
       <!--property标签:设置注入属性-->
       <!--name属性:设置注入的属性名,实际是set方法对应的名称-->
       <!--value属性:设置注入简单类型数据值-->
       <property name="connectionNum" value="100"/>
       <property name="databaseName" value="mysql"/>
   </bean>

三、构造器注入

引用类型

在bean中定义引用类型属性并提供可访问的构造方法

public class BookServiceImpl implements BookService{
   private BookDao bookDao;
   private UserDao userDao;

public BookServiceImpl(BookDao bookDao, UserDao userDao) {
       this.bookDao = bookDao;
       this.userDao = userDao;
   }
}

配置中使用constructor-arg标签ref属性注入引用类型对象

<bean id="bookDao" class="com.itheima.dao.impl.BookDaoImpl"/>
<bean id="userDao" class="com.itheima.dao.impl.UserDaoImpl"/>

<bean id="bookService" class="com.itheima.service.impl.BookServiceImpl">
       <constructor-arg name="userDao" ref="userDao"/>
       <constructor-arg name="bookDao" ref="bookDao"/>
   </bean>

简单类型

在bean中定义引用类型属性并提供可访问的构造方法

public class BookDaoImpl implements BookDao {
   private String databaseName;
   private int connectionNum;

public BookDaoImpl(String databaseName, int connectionNum) {
       this.databaseName = databaseName;
       this.connectionNum = connectionNum;
   }
}

配置中使用constructor-arg标签ref属性注入引用类型对象

<bean id="bookDao" class="com.itheima.dao.impl.BookDaoImpl">
       <!--根据构造方法参数名称注入-->
       <constructor-arg name="connectionNum" value="10"/>
       <constructor-arg name="databaseName" value="mysql"/>
</bean>

参数适配(了解)

配置中使用constructor-arg标签type属性注入引用类型对象

<!--解决形参名称的问题,与形参名不耦合-->
   <bean id="bookDao" class="com.itheima.dao.impl.BookDaoImpl">
       <!--根据构造方法参数类型注入-->
       <constructor-arg type="int" value="10"/>
       <constructor-arg type="java.lang.String" value="mysql"/>
   </bean>

配置中使用constructor-arg标签index属性注入引用类型对象

<!--解决参数类型重复问题,使用位置解决参数匹配-->
   <bean id="bookDao" class="com.itheima.dao.impl.BookDaoImpl">
       <!--根据构造方法参数位置注入-->
       <constructor-arg index="0" value="mysql"/>
       <constructor-arg index="1" value="100"/>
   </bean>

四、依赖注入方式选择

1、强制依赖使用构造器进入,使用setter注入有概率不进入注入导致null对象出现

2、可选依赖使用setter注入进行,灵活性强

3、Spring框架倡导使用构造器,第三方框架内部大多数采用构造器注入的形式进行数据初始化,相对严谨

4、如果有必要可以两者同时使用,使用构造器注入完成强制依赖的注入,使用setter注入完成可依赖的注入

5、实际开发过程中还要根据实际情况分析,如果受控对象没有提供setter方法就必须使用构造器注入

6、自己开发的模块推荐使用setter注入

来源:https://blog.csdn.net/m0_61961937/article/details/125177294

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com