spring源码学习之【准备】jdk动态代理例子

简介: 一:被代理的对象所要实现的接口 1 package com.yeepay.testpoxy; 2 3 import java.util.Map; 4 5 /** 6 * 被动态代理的接口 7 * @author shangxiaofei 8 * 9...

一:被代理的对象所要实现的接口

 1 package com.yeepay.testpoxy;
 2 
 3 import java.util.Map;
 4 
 5 /**
 6  * 被动态代理的接口
 7  * @author shangxiaofei
 8  *
 9  */
10 public interface MyCheckPay {
11     /**
12      * 付钱的接口
13      * @param name
14      * @param money
15      * @return
16      */
17     public Map<String, String> payMoney(String name,Integer money);
18 }
View Code

二:被动态代理的实现类

 1 package com.yeepay.testpoxy;
 2 
 3 import java.util.HashMap;
 4 import java.util.Map;
 5 
 6 /**
 7  * 被动态代理的实现类
 8  * @author shangxiaofei
 9  *
10  */
11 public class ShangxiaofeiMyCheckPay implements MyCheckPay{
12 
13     @Override
14     public Map<String, String> payMoney(String name, Integer money) {
15         System.out.println("ShangxiaofeiMyCheckPay.payMoney()========>name=["+name+"],payMoney=["+money+"]");
16         Map<String, String> map=new HashMap<String, String>();
17         map.put("result",name+"付钱"+money+"元,已经结束");
18         return map;
19     }
20 
21     
22     
23 }
View Code

三:动态代理的增强类(代理类)

 1 package com.yeepay.testpoxy;
 2 
 3 import java.lang.reflect.InvocationHandler;
 4 import java.lang.reflect.Method;
 5 
 6 /**
 7  * 增加功能的类
 8  * @author shangxiaofei
 9  *
10  */
11 public class HandlerForMyCheckPay implements InvocationHandler{
12     /**
13      * 被委托的类的引用
14      */
15     private Object object;
16 
17     
18     
19     /**
20      * 空构造
21      */
22     public HandlerForMyCheckPay() {
23     
24     }
25 
26 
27 
28     /**
29      * 有参构造
30      * @param object
31      */
32     public HandlerForMyCheckPay(Object object) {
33         this.object = object;
34     }
35 
36 
37 
38 
39     /**
40      * Object proxy:指代我们所代理的那个真实对象,这个对象不能使用,否则会引起栈溢出
41      * Method method: 指代的是我们所要调用真实对象的某个方法的Method对象
42      * Object[] args: 指代的是调用真实对象某个方法时接受的参数
43      */
44     @Override
45     public Object invoke(Object proxy, Method method, Object[] args)throws Throwable {
46         
47         /**
48          * 被代理对象调用方法之前调用(aop的前置增强)
49          */
50         System.out.println("HandlerForMyCheckPay.invoke()=======>【付钱前】向统计系统发送付钱消息");
51         if(args!=null&&args.length>0){
52             for(int i=0;i<args.length;i++){
53                 System.out.println("HandlerForMyCheckPay.invoke()发送消息为===>"+args[i]);
54             }
55         }
56         
57         
58         /**
59          * 调用被代理对象的实际的方法
60          */
61         Object d=method.invoke(this.object, args);
62     
63         
64         /**
65          * 调用被代理对象的实际的方法之后执行:后置增强
66          */
67         System.out.println("HandlerForMyCheckPay.invoke()=======>【付钱后】进行计算执行时长");
68         
69         return d;
70     }
71     
72     
73 
74 }
View Code

四:代理类的生产工厂

 1 package com.yeepay.testpoxy;
 2 
 3 import java.lang.reflect.Proxy;
 4 
 5 /**
 6  * 生产代理者的工厂类
 7  * @author shangxiaofei
 8  *
 9  */
10 public class ProxyFactory {
11 
12     public static MyCheckPay getMyCheckPay(){
13         
14         /**
15          * ClassLoader loader:一个ClassLoader对象,定义了由哪个ClassLoader对象来对生成的代理对象进行加载
16          * Class<?>[] interfaces: 一个Interface对象的数组,表示的是我将要给我需要代理的对象提供一组什么接口,如果我提供了一组接口给它,那么这个代理对象就宣称实现了该接口(多态),这样我就能调用这组接口中的方法了
17          * InvocationHandler h:一个InvocationHandler对象,表示的是当我这个动态代理对象在调用方法的时候,会关联到哪一个InvocationHandler对象上
18          */
19         Object object=Proxy.newProxyInstance(ProxyFactory.class.getClassLoader(), new Class[]{MyCheckPay.class},new HandlerForMyCheckPay(new ShangxiaofeiMyCheckPay()));
20         return (MyCheckPay) object;
21     }
22     
23     
24     public static MyCheckPay getMyCheckPay2(){
25         
26         /**
27          * ClassLoader loader:一个ClassLoader对象,定义了由哪个ClassLoader对象来对生成的代理对象进行加载
28          * Class<?>[] interfaces: 一个Interface对象的数组,表示的是我将要给我需要代理的对象提供一组什么接口,如果我提供了一组接口给它,那么这个代理对象就宣称实现了该接口(多态),这样我就能调用这组接口中的方法了
29          * InvocationHandler h:一个InvocationHandler对象,表示的是当我这个动态代理对象在调用方法的时候,会关联到哪一个InvocationHandler对象上
30          */
31         Object object=Proxy.newProxyInstance(ProxyFactory.class.getClassLoader(),MyCheckPay.class.getInterfaces(),new HandlerForMyCheckPay(new ShangxiaofeiMyCheckPay()));
32         return (MyCheckPay) object;
33     }
34 }
View Code

五:测试类

 1 package com.yeepay.testpoxy;
 2 
 3 import java.util.Map;
 4 
 5 /**
 6  * 测试动态代理
 7  * @author shangxiaofei
 8  *
 9  */
10 public class TestController {
11 
12     private MyCheckPay myCheckPay=ProxyFactory.getMyCheckPay();
13     
14     public void payMoney(String name,Integer money){
15         System.out.println("TestController.payMoney(开始)");
16         Map<String, String> map=myCheckPay.payMoney(name, money);
17         System.out.println("TestController.payMoney(结束)"+map.get("result"));
18     }
19     
20     /**
21      * TestController.payMoney(开始)
22      *HandlerForMyCheckPay.invoke()=======>【付钱前】向统计系统发送付钱消息
23      *HandlerForMyCheckPay.invoke()发送消息为===>怪物雷克
24      *HandlerForMyCheckPay.invoke()发送消息为===>100
25      *ShangxiaofeiMyCheckPay.payMoney()========>name=[怪物雷克],payMoney=[100]
26      *HandlerForMyCheckPay.invoke()=======>【付钱后】进行计算执行时长
27      *TestController.payMoney(结束)怪物雷克付钱100元,已经结束
28      * @param args
29      */
30     public static void main(String[] args) {
31         TestController testController=new TestController();
32         testController.payMoney("怪物雷克", 100);    
33     }
34     
35 }
View Code

 

相关文章
|
1月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
68 2
|
1月前
|
数据采集 监控 前端开发
二级公立医院绩效考核系统源码,B/S架构,前后端分别基于Spring Boot和Avue框架
医院绩效管理系统通过与HIS系统的无缝对接,实现数据网络化采集、评价结果透明化管理及奖金分配自动化生成。系统涵盖科室和个人绩效考核、医疗质量考核、数据采集、绩效工资核算、收支核算、工作量统计、单项奖惩等功能,提升绩效评估的全面性、准确性和公正性。技术栈采用B/S架构,前后端分别基于Spring Boot和Avue框架。
|
14天前
|
存储 缓存 Java
Spring面试必问:手写Spring IoC 循环依赖底层源码剖析
在Spring框架中,IoC(Inversion of Control,控制反转)是一个核心概念,它允许容器管理对象的生命周期和依赖关系。然而,在实际应用中,我们可能会遇到对象间的循环依赖问题。本文将深入探讨Spring如何解决IoC中的循环依赖问题,并通过手写源码的方式,让你对其底层原理有一个全新的认识。
30 2
|
22天前
|
Java 开发者 Spring
Spring AOP深度解析:探秘动态代理与增强逻辑
Spring框架中的AOP(Aspect-Oriented Programming,面向切面编程)功能为开发者提供了一种强大的工具,用以将横切关注点(如日志、事务管理等)与业务逻辑分离。本文将深入探讨Spring AOP的底层原理,包括动态代理机制和增强逻辑的实现。
33 4
|
1月前
|
前端开发 Java 开发者
Spring生态学习路径与源码深度探讨
【11月更文挑战第13天】Spring框架作为Java企业级开发中的核心框架,其丰富的生态系统和强大的功能吸引了无数开发者的关注。学习Spring生态不仅仅是掌握Spring Framework本身,更需要深入理解其周边组件和工具,以及源码的底层实现逻辑。本文将从Spring生态的学习路径入手,详细探讨如何系统地学习Spring,并深入解析各个重点的底层实现逻辑。
62 9
|
2月前
|
前端开发 Java 数据库
SpringBoot学习
【10月更文挑战第7天】Spring学习
39 9
|
26天前
|
Java Kotlin 索引
学习Spring框架特性及jiar包下载
Spring 5作为最新版本,更新了JDK基线至8,修订了核心框架,增强了反射和接口功能,支持响应式编程及Kotlin语言,引入了函数式Web框架,并提升了测试功能。Spring框架可在其官网下载,包括文档、jar包和XML Schema文档,适用于Java SE和Java EE项目。
29 0
|
2月前
|
Java 数据安全/隐私保护 Spring
Spring进阶:初识动态代理
本文介绍了Spring框架中AOP切面编程的基础——动态代理。通过定义Vehicle接口及其实现类Car和Ship,展示了如何使用动态代理在不修改原代码的基础上增强功能。文章详细解释了动态代理的工作原理,包括通过`Proxy.newProxyInstance()`方法创建代理对象,以及`InvocationHandler`接口中的`invoke()`方法如何处理代理对象的方法调用。最后,通过一个测试类`TestVehicle`演示了动态代理的具体应用。
|
2月前
|
XML Java 数据格式
Spring学习
【10月更文挑战第6天】Spring学习
23 1
|
2月前
|
Java 测试技术 开发者
springboot学习四:Spring Boot profile多环境配置、devtools热部署
这篇文章主要介绍了如何在Spring Boot中进行多环境配置以及如何整合DevTools实现热部署,以提高开发效率。
97 2