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 @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一