Spring的控制反转、依赖注入及面向切面编程

2024-06-17 12:48

本文主要是介绍Spring的控制反转、依赖注入及面向切面编程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、控制反转(IoC):

一个类A的内部需要另一个类B的对象,如果在其中进行创建,则A、B两个类会发生高度耦合。这时,采用控制反转思想,利用Spring的配置文件设置Spring,对B进行创建对象,并存于Spring容器中,待A需要B的对象时,会对Spring发出请求getBean,接着Spring容器将B的对象交由A来完成协作。至于B的对象时何时创建,如何创建,均不由A管理,达到对于A和B的解耦合目的,创建对象的控制由A类本体,转移到Spring,A仅仅是等待接收,这就是控制反转。

二、依赖注入(DI):

起本质与控制反转为同意义,所谓的依赖注入,就是把所依赖的数据,利用spring进行注入,查询Spring容器内的数据后构建依赖关系。在A类需要B类的对象时,B类中如果包含属性,可以对属性进行依赖的数据注入,这样,A类获取的B类的对象,就是包含了其所拥有的的属性值的对象。而如果B类的属性为引用类型的属性——C类,则C类的内部,又将会有自己的属性,可以再次对C类的属性进行数据注入,形成层层注入,最终获得的B类的对象,是一个成品的、将内部的各层级属性均附上相应的值的对象。如下面的例子,一起将三层架构内的关联对象层层注入,全部赋值,则对web层提供的Service对象(以“a”为获取方式),是一个各层级完全赋值的对象,XML配置如下所示:

<--web层的getBean以a为坐标,获取service-->
<bean id="a" class="com.fh.service.impl.CountryServiceImpl"><property name="countryDao" ref="b"/>
</bean><bean id="b" class="com.fh.dao.impl.CountryDaoImpl"><property name="queryRunner" ref="c"/>
</bean><bean id="c" class="org.apache.commons.dbutils.QueryRunner"><constructor-arg name="ds" ref="d"/>
</bean><bean id="d" class="com.alibaba.druid.pool.DruidDataSource"><property name="driverClassName" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/demo1"/><property name="username" value="root"/><property name="password" value="root"/>
</bean>

三、面向切面编程(AOP):

被代理对象:包含核心业务代码的对象。
代理对象:spring容器中产生的、对被代理对象增强后的对象。
连接点:核心业务代码中的所有方法均被称作连接点(joinpoint)。
切入点:核心业务代码中,被选中进行增强的方法,叫做切入点(pointcut)。
通知对象(advice):增强核心业务代码的对象,包括如:事务、日志等。
织入:把通知类中的代码与切入点中的代码编写到一起的过程。
切面(aspect):切入点(核心业务代码)和通知类(其余额外代码)共同构成切面。
面向切面编程,就是编码时只关心核心业务代码,对于事务、日志等额外代码单独抽取,最终运行时,源码中利用动态代理,将核心业务设置为被代理对象,事务、日志等设置为增强的功能,最终织入在一起,获取代理对象。

动态代理的实现方式:

JDK Proxy 和 CGLib 的区别主要体现在以下几个方面:

JDK Proxy 是 Java 语言自带的功能,无需通过加载第三方类实现;
Java 对 JDK Proxy 提供了稳定的支持,并且会持续的升级和更新 JDK Proxy,例如 Java 8 版本中的 JDK Proxy 性能相比于之前版本提升了很多;
JDK Proxy 是通过拦截器加反射的方式实现的;
JDK Proxy 只能代理继承接口的类;
JDK Proxy 实现和调用起来比较简单;

CGLib 是第三方提供的工具,基于 ASM(一个 Java 字节码操作框架) 实现的,性能比较高;
CGLib 无需通过接口来实现,它是通过实现子类的方式来完成调用的。

这篇关于Spring的控制反转、依赖注入及面向切面编程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1069491

相关文章

Java五子棋之坐标校正

上篇针对了Java项目中的解构思维,在这篇内容中我们不妨从整体项目中拆解拿出一个非常重要的五子棋逻辑实现:坐标校正,我们如何使漫无目的鼠标点击变得有序化和可控化呢? 目录 一、从鼠标监听到获取坐标 1.MouseListener和MouseAdapter 2.mousePressed方法 二、坐标校正的具体实现方法 1.关于fillOval方法 2.坐标获取 3.坐标转换 4.坐

Spring Cloud:构建分布式系统的利器

引言 在当今的云计算和微服务架构时代,构建高效、可靠的分布式系统成为软件开发的重要任务。Spring Cloud 提供了一套完整的解决方案,帮助开发者快速构建分布式系统中的一些常见模式(例如配置管理、服务发现、断路器等)。本文将探讨 Spring Cloud 的定义、核心组件、应用场景以及未来的发展趋势。 什么是 Spring Cloud Spring Cloud 是一个基于 Spring

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

java8的新特性之一(Java Lambda表达式)

1:Java8的新特性 Lambda 表达式: 允许以更简洁的方式表示匿名函数(或称为闭包)。可以将Lambda表达式作为参数传递给方法或赋值给函数式接口类型的变量。 Stream API: 提供了一种处理集合数据的流式处理方式,支持函数式编程风格。 允许以声明性方式处理数据集合(如List、Set等)。提供了一系列操作,如map、filter、reduce等,以支持复杂的查询和转

Java面试八股之怎么通过Java程序判断JVM是32位还是64位

怎么通过Java程序判断JVM是32位还是64位 可以通过Java程序内部检查系统属性来判断当前运行的JVM是32位还是64位。以下是一个简单的方法: public class JvmBitCheck {public static void main(String[] args) {String arch = System.getProperty("os.arch");String dataM

详细分析Springmvc中的@ModelAttribute基本知识(附Demo)

目录 前言1. 注解用法1.1 方法参数1.2 方法1.3 类 2. 注解场景2.1 表单参数2.2 AJAX请求2.3 文件上传 3. 实战4. 总结 前言 将请求参数绑定到模型对象上,或者在请求处理之前添加模型属性 可以在方法参数、方法或者类上使用 一般适用这几种场景: 表单处理:通过 @ModelAttribute 将表单数据绑定到模型对象上预处理逻辑:在请求处理之前

eclipse运行springboot项目,找不到主类

解决办法尝试了很多种,下载sts压缩包行不通。最后解决办法如图: help--->Eclipse Marketplace--->Popular--->找到Spring Tools 3---->Installed。

JAVA读取MongoDB中的二进制图片并显示在页面上

1:Jsp页面: <td><img src="${ctx}/mongoImg/show"></td> 2:xml配置: <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001

零基础STM32单片机编程入门(一)初识STM32单片机

文章目录 一.概要二.单片机型号命名规则三.STM32F103系统架构四.STM32F103C8T6单片机启动流程五.STM32F103C8T6单片机主要外设资源六.编程过程中芯片数据手册的作用1.单片机外设资源情况2.STM32单片机内部框图3.STM32单片机管脚图4.STM32单片机每个管脚可配功能5.单片机功耗数据6.FALSH编程时间,擦写次数7.I/O高低电平电压表格8.外设接口

Java面试题:通过实例说明内连接、左外连接和右外连接的区别

在 SQL 中,连接(JOIN)用于在多个表之间组合行。最常用的连接类型是内连接(INNER JOIN)、左外连接(LEFT OUTER JOIN)和右外连接(RIGHT OUTER JOIN)。它们的主要区别在于它们如何处理表之间的匹配和不匹配行。下面是每种连接的详细说明和示例。 表示例 假设有两个表:Customers 和 Orders。 Customers CustomerIDCus