Spring-IOC实现

2024-08-30 17:08
文章标签 java 实现 spring ioc

本文主要是介绍Spring-IOC实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1 导入依赖和插件
  • 2 实现
    • 2.1 bean标签
      • 2.1.1 构造对象
        • 2.1.1.1 调用无参构造
        • 2.1.1.2 调用有参构造
      • 2.1.2 通过工厂创建对象
        • 2.1.2.1 通过工厂的静态方法
        • 2.1.2.2 通过工厂的实例方法
      • 2.1.3 基于XML的依赖注入
        • 2.1.3.1 通过有参的构造函数
        • 2.1.3.2 通过property标签(普通注入和自动注入)
    • 2.2 基于注解实现IoC
      • 2.2.1 声明bean的注解:@Component、@Repository、@Service、@Controller
      • 2.2.2 给bean加上限制
      • 2.2.2 包扫描
      • 2.2.3 属性注入:@Value
      • 2.2.4 声明属性的注解(依赖注入)
        • 2.2.4.1 通过类型:@Autowired
        • 2.2.4.2 通过名称:@Autowired+@Qualifier


1 导入依赖和插件

<dependencies>
<!--单元测试-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<!--spring依赖-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.2.13.RELEASE</version>
</dependency>
</dependencies>
<build>
<plugins>
<!--编译插件-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.0</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>

2 实现

IoC的主要作用就是,对于bean对象的创建,不需要通过new关键字实现了,可以通过Spring容器获得。

原理:在配置文件中通过<bean>标签,指定id、class等信息,使Spring容器构造一个对象放到容器里。

2.1 bean标签

在beans标签下可以声明多个bean标签。每个bean都代表一个对象。

2.1.1 构造对象

2.1.1.1 调用无参构造
<bean id="team" class="com.kkb.xzk.bean.Team" scope="singleton" lazy-init="false"></bean>

属性解释:

  • id:对象的唯一标识,不能出现特殊的字符
  • name:对象的名称,可以出现特殊字符
  • class:完整的包名.类名,指定对象是哪一个特定的类
  • scope:对象的创建形式,有以下两种:
    • singleton(默认):单例模式。默认当ApplicationContext创建的时候就创建此对象。在getBean(String id)获取的时候,同一个id得到的是同一个对象。
    • prototype :多例模式。在ApplicationContext创建的时候,不会创建此对象。只有调用getBean时对象才会创建,并且每次得到的是不同的对象。
  • lazy-init:是否延迟创建。这个其实就是单例模式中的懒汉和饿汉模式。
    • false(默认):饿汉模式,当ApplicationContext创建时就会自动创建该对象。
    • true:懒汉模式,只有在getBean时才会创建该对象。
2.1.1.2 调用有参构造
<bean id="team2" class="com.kkb.xzk.bean.Team"><constructor-arg name="name" value="热火" /><constructor-arg name="location" value="迈阿密" />
</bean>
  • 所有的普通类型参数,使用value赋值;
  • 所有的引用类型参数,使用ref赋值;

2.1.2 通过工厂创建对象

2.1.2.1 通过工厂的静态方法
<!--通过工厂类静态方法得到实例对象-->
<!--等价于调用:Team staticTeam = MyFactory.getTeam()-->
<bean id="staticTeam" class="com.kkb.xzk.factory.MyFactory" factory-method="getTeam" >
</bean>
2.1.2.2 通过工厂的实例方法

既然是实例方法,则首先需要创建工厂的实例对象,然后通过工厂对象再创建bean对象。

<!--通过工厂类的实例方法得到对象-->
<!--需要先创建工厂类对象-->
<!--等价于:factory = new MyFactory(); instanceTeam = factory.getTeamInstance();-->
<bean id="factory" class="com.kkb.xzk.factory.MyFactory" />
<bean id="instanceTeam" factory-bean="factory" factory-method="getTeamInstance" />
  • 如果没有声明factory-bean,class指定的是工厂类,factory-method指定的是工厂类的静态方法。
  • 如果声明了factory-bean,则不会使用class属性。factory-method指定的是工厂类的实例方法。

2.1.3 基于XML的依赖注入

有了对象之后,如何给对象里的属性赋值呢?

属性分为一般类型(int, String, boolean等)和引用类型(对象),前者需要通过value赋值,后者需要通过ref赋值。

2.1.3.1 通过有参的构造函数

上面提到过了,这里忽略。

2.1.3.2 通过property标签(普通注入和自动注入)

注入的原理是调用setter方法。因此相关对象必须设置各种属性的set方法

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"><bean id="teamDao" class="com.kkb.xzk.dao.TeamDao" ></bean><!--通过set方法注入--><bean id="teamService" class="com.kkb.xzk.service.TeamService"><property name="teamDao" ref="teamDao"></property></bean><!--通过构造方法注入--><bean id="teamService2" class="com.kkb.xzk.service.TeamService"><constructor-arg name="teamDao" ref="teamDao" /></bean><!--自动注入:byName--><!--找到与参数名称相同的bean id--><bean id="teamService3" class="com.kkb.xzk.service.TeamService" autowire="byName"></bean><!--自动注入:byType--><!--找到和参数类型相同或者为参数类型子类的bean--><bean id="teamService4" class="com.kkb.xzk.service.TeamService" autowire="byType"></bean>
</beans>

2.2 基于注解实现IoC

通过注解,可以不需要在xml中声明各种bean标签来实现对象创建。在类声明的时候通过注解来使spring可以扫描到相关类。

2.2.1 声明bean的注解:@Component、@Repository、@Service、@Controller

后三者是第一个的子注解。
@Component:通用的bean声明
@Repository:对Dao的声明
@Service:对Service的声明
@Controller:对Controller的声明

  • @Component(value="team1") 等价于:<bean id="team1 class="com.kkb.xzk.bean.Team">
  • value可以省略
  • 括号也可以省略。此时对象对应的id是把首字母小写的类名。@Component声明在Team类上,则默认是得到了一个id为team的对象。

2.2.2 给bean加上限制

在spring的配置文件中,可以给bean加上scope和lazy-init的属性。那么在注解中如何实现?通过注解@Scope@Lazy实现。

2.2.2 包扫描

在spring配置文件中,添加对包的扫描。

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd "><context:component-scan base-package="com.kkb.xzk.bean, com.kkb.xzk.dao, com.kkb.xzk.service, com.kkb.xzk.controller" />
</beans>

2.2.3 属性注入:@Value

通过属性注入给属性赋值,不需要有setter方法。

@Component
public class Team {@Value("太阳")private String name;@Value("凤凰城")private String location;
...
}

2.2.4 声明属性的注解(依赖注入)

2.2.4.1 通过类型:@Autowired
2.2.4.2 通过名称:@Autowired+@Qualifier
@Service
public class TeamService {@Autowired // 按照类型注入@Qualifier("team1") // 如果增加Qualifier注解,则是按照名称byName注入private TeamDao teamDao;public TeamService() {System.out.println("TeamService构造方法调用");}public TeamService(TeamDao teamDao) {this.teamDao = teamDao;}public void add(){teamDao.add();System.out.println("TeamService: add()执行");}public TeamDao getTeamDao() {return teamDao;}public void setTeamDao(TeamDao teamDao) {this.teamDao = teamDao;}
}

这篇关于Spring-IOC实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1121426

相关文章

Spring Boot中获取IOC容器的多种方式

《SpringBoot中获取IOC容器的多种方式》本文主要介绍了SpringBoot中获取IOC容器的多种方式,包括直接注入、实现ApplicationContextAware接口、通过Spring... 目录1. 直接注入ApplicationContext2. 实现ApplicationContextA

详解Spring中REQUIRED事务的回滚机制详解

《详解Spring中REQUIRED事务的回滚机制详解》在Spring的事务管理中,REQUIRED是最常用也是默认的事务传播属性,本文就来详细的介绍一下Spring中REQUIRED事务的回滚机制,... 目录1. REQUIRED 的定义2. REQUIRED 下的回滚机制2.1 异常触发回滚2.2 回

linux部署NFS和autofs自动挂载实现过程

《linux部署NFS和autofs自动挂载实现过程》文章介绍了NFS(网络文件系统)和Autofs的原理与配置,NFS通过RPC实现跨系统文件共享,需配置/etc/exports和nfs.conf,... 目录(一)NFS1. 什么是NFS2.NFS守护进程3.RPC服务4. 原理5. 部署5.1安装NF

Python实现自动化删除Word文档超链接的实用技巧

《Python实现自动化删除Word文档超链接的实用技巧》在日常工作中,我们经常需要处理各种Word文档,本文将深入探讨如何利用Python,特别是借助一个功能强大的库,高效移除Word文档中的超链接... 目录为什么需要移除Word文档超链接准备工作:环境搭建与库安装核心实现:使用python移除超链接的

Java 单元测试之Mockito 模拟静态方法与私有方法最佳实践

《Java单元测试之Mockito模拟静态方法与私有方法最佳实践》本文将深入探讨如何使用Mockito来模拟静态方法和私有方法,结合大量实战代码示例,带你突破传统单元测试的边界,写出更彻底、更独立... 目录Mockito 简介:为什么选择它?环境准备模拟静态方法:打破“不可变”的枷锁传统困境解法一:使用M

linux查找java项目日志查找报错信息方式

《linux查找java项目日志查找报错信息方式》日志查找定位步骤:进入项目,用tail-f实时跟踪日志,tail-n1000查看末尾1000行,grep搜索关键词或时间,vim内精准查找并高亮定位,... 目录日志查找定位在当前文件里找到报错消息总结日志查找定位1.cd 进入项目2.正常日志 和错误日

Java中最全最基础的IO流概述和简介案例分析

《Java中最全最基础的IO流概述和简介案例分析》JavaIO流用于程序与外部设备的数据交互,分为字节流(InputStream/OutputStream)和字符流(Reader/Writer),处理... 目录IO流简介IO是什么应用场景IO流的分类流的超类类型字节文件流应用简介核心API文件输出流应用文

Python Excel 通用筛选函数的实现

《PythonExcel通用筛选函数的实现》本文主要介绍了PythonExcel通用筛选函数的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录案例目的示例数据假定数据来源是字典优化:通用CSV数据处理函数使用说明使用示例注意事项案例目的第一

C#使用SendMessage实现进程间通信的示例代码

《C#使用SendMessage实现进程间通信的示例代码》在软件开发中,进程间通信(IPC)是关键技术之一,C#通过调用WindowsAPI的SendMessage函数实现这一功能,本文将通过实例介绍... 目录第一章:SendMessage的底层原理揭秘第二章:构建跨进程通信桥梁2.1 定义通信协议2.2

JAVA实现亿级千万级数据顺序导出的示例代码

《JAVA实现亿级千万级数据顺序导出的示例代码》本文主要介绍了JAVA实现亿级千万级数据顺序导出的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 前提:主要考虑控制内存占用空间,避免出现同时导出,导致主程序OOM问题。实现思路:A.启用线程池