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

相关文章

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法