熟知代理模式,你将明白Spring AOP原理!!!

2024-02-01 23:48

本文主要是介绍熟知代理模式,你将明白Spring AOP原理!!!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

01.什么是代理模式?

  解析:代理(Proxy):代理模式的主要作用是为其他对象提供一种代理以控制对这个对象的访问。在某些情况下,一个对象不想或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用。代理模式的思想是为了提供额外的处理或者不同的操作而在实际对象与调用者之间插入一个代理对象。

这些额外的操作通常需要与实际对象进行通信。

02.代理的组成都有什么?

解析:由三部分组成,分别是:抽象对象(Subject 接口),真实对象(RealSubject 实现了Subject接口),代理对象(ProxySubject)

        

03.代理对象作用场景?

解析: 第一,远程代理,也就是为一个对象在不同的地址空间提供局部代表.这样可以隐藏一个对象存在于不同地址空间的事实[DP].

         第二:需补代理,是根据需要创建开销很大的对象.通过它来存放实例化需要很长时间的真实对象[DP].这样就可以达到性能的最优化.

04.代理有几种?

解析:代理有两种类型,即 动态代理和静态代理,

动态代理:动态代理,在Struts和Spring等框架中都用到了动态代理,用于帮助程序员生成其要使用的类的子类或本类,这样框架就可以再代码之前做一些动作,

比如前置方法增强,后置方法增强,记录日志,异常捕获等等.在程序运行时运用反射机制动态创建而成(插: AOP(AspectOrientedProgramming):将日志记录,性能统计,安全控制,事务处理,异常处理等代码从业务逻辑代码中划分出来,通过对这些行为的分离,我们希望可以将它们独立到非指导业务逻辑的方法中,进而改变这些行为的时候不影响业务逻辑的代码---解耦。)

静态代理:由程序员创建代理类或特定工具自动生成源代码再对其编译。在程序运行前代理类的.class文件就已经存在了。

 

动态代理 VS 静态代理:

静态代理类优缺点

  优点:

代理使客户端不需要知道实现类是什么,怎么做的,而客户端只需知道代理即可(解耦合)

  缺点:

  1)代理类和委托类实现了相同的接口,代理类通过委托类实现了相同的方法。这样就出现了大量的代码重复。如果接口增加一个方法,

除了所有实现类需要实现这个方法外,所有代理类也需要实现此方法。增加了代码维护的复杂度。

  2)代理对象只服务于一种类型的对象,如果要服务多类型的对象。势必要为每一种对象都进行代理,静态代理在程序规模稍大时就无法胜任了。

如上的代码是只为UserManager类的访问提供了代理,但是如果还要为其他类如Department类提供代理的话,就需要我们再次添加代理Department的代理类。

 静态代理---------->案列

 01.创建一个接口:

package cn.work.proxy;
//抽象对象
public interface Subject {public String request();
}

   02.创建一个实现类:

package cn.work.proxy;
//真实对象
public class RealSubject implements Subject {public String request() {return "真实对象";}}

  03.创建一个代理对象:

package cn.work.proxy;public class ProxySubject {//把抽象对象组成代理对象的字段private Subject sub;public Subject getSub() {return sub;}public void setSub(Subject sub) {this.sub = sub;}public String reqString(){System.out.println("代理增强");return sub.request();}
}

   04.创建Test测试类:

//对象代理@Testpublic void test09() {Subject sub=new RealSubject();ProxySubject ps=new ProxySubject();ps.setSub(sub);System.out.println(ps.reqString());}

动态代理优点:

动态代理与静态代理相比较,最大的好处是接口中声明的所有方法都被转移到调用处理器一个集中的方法中处理(InvocationHandler.invoke)。这样,

在接口方法数量比较多的时候,我们可以进行灵活处理,而不需要像静态代理那样每一个方法进行中转。而且动态代理的应用使我们的类职责更加单一,复用性更强.

动态代理--------->实例

01.创建一个DAO接口

package cn.work.dao;import cn.work.entity.User;public interface UserDao {public void add(User user);
}

02.创建一个DAO接口的实现

package cn.work.dao;import cn.work.entity.User;public class UserImpl implements UserDao{public void add(User user) {System.out.println("sava success");}}

03.创建测试类

@Test
public void test10(){User user=new User();final UserDao userDao=new UserImpl();UserDao u =(UserDao) Proxy.newProxyInstance(userDao.getClass().getClassLoader(),userDao.getClass().getInterfaces(), new InvocationHandler() {public Object invoke(Object proxy, Method method, Object[] args)throws Throwable {System.out.println("代码增强");return method.invoke(userDao, args);}} );u.add(user);
}

参数说明:  

  Proxy.newProxyInstance(loader, interfaces, h)

  loader:类加载器,传入你要代理的对象,通过 对象名.getClass().getClassLoader()来拿到该对象的类加载器.

  interfaces:被代理对象的所有实现接口的集合

   InvocationHandler 是代理实例的调用处理程序 实现的接口实现InvcationHandler内部类,
new InvcationHandler(){public Object invoke(Object proxy, Method method, Object[] args)throws Throwable {......return ....;}
}

    扫一扫,有惊喜!

这篇关于熟知代理模式,你将明白Spring AOP原理!!!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

高效+灵活,万博智云全球发布AWS无代理跨云容灾方案!

摘要 近日,万博智云推出了基于AWS的无代理跨云容灾解决方案,并与拉丁美洲,中东,亚洲的合作伙伴面向全球开展了联合发布。这一方案以AWS应用环境为基础,将HyperBDR平台的高效、灵活和成本效益优势与无代理功能相结合,为全球企业带来实现了更便捷、经济的数据保护。 一、全球联合发布 9月2日,万博智云CEO Michael Wong在线上平台发布AWS无代理跨云容灾解决方案的阐述视频,介绍了