zoukankan      html  css  js  c++  java
  • java动态代理--一个简单的例子

    这几天看视频看到了java的动态代理,这里写一个小例子。在写例子的时候发现:认为自己会了,和能写出来真不是一个概念。还是要多写代码,然后写博客再深入一些,费曼学习法--教,是最好的学。

    1.什么是动态代理

    代理模式 
    代理模式是常用的java设计模式,他的特征是代理类与委托类有同样的接口,代理类主要负责为委托类预处理消息、过滤消息、把消息转发给委托类,以及事后处理消息等。代理类与委托类之间通常会存在关联关系,一个代理类的对象与一个委托类的对象关联,代理类的对象本身并不真正实现服务,而是通过调用委托类的对象的相关方法,来提供特定的服务。 
    按照代理的创建时期,代理类可以分为两种。 
    静态代理:由程序员创建或特定工具自动生成源代码,再对其编译。在程序运行前,代理类的.class文件就已经存在了。 
    动态代理:在程序运行时,运用反射机制动态创建而成。

    2.动态代理的Demo

    首先创建一个接口,PersonDao

    public interface PersonDao {
    	public void say();
    }
    

    然后写一个实现类PersonDaoImpl

    public class PersonDaoImpl implements PersonDao{
    
    	@Override
    	public void say() {
    		System.out.println("time to eat");
    	}
    
    }
    

    然后写个使用类PersonHandler

    public class PersonHandler implements InvocationHandler {
    
    	private Object obj;
    	
    	public PersonHandler(Object obj){
    		this.obj=obj;
    	}
    	
    	
    	@Override
    	public Object invoke(Object proxy, Method method, Object[] args)
    			throws Throwable {
    		
    		System.out.println("before");
    		Object result = method.invoke(obj, args);
    		System.out.println("after");
    		return result;
    	}
    
    }
    


    PersonHandler必须要实现InvocationHandler接口

    然后 再写个测试类

    public class PersonTest {
    	
    	@Test
    	public void test(){
    		PersonDao pDao = new PersonDaoImpl();
    		PersonHandler handler = new PersonHandler(pDao);
    		
    		PersonDao proxy = (PersonDao)Proxy.newProxyInstance(pDao.getClass().getClassLoader(), pDao.getClass().getInterfaces(), handler);
    		proxy.say();
    	}
    }
    
    最后控制台输出


    至于具体细节,可能要研究一下源码了,有时间再说吧




  • 相关阅读:
    react绑定事件
    js基础
    浅谈vue中index.html、main.js、App.vue、index.js之前的关系以及加载过程
    jmeter+influxdb+grafana搭建压测监控平台
    javascript中的constructor
    javascript es6新增语法之`${}`
    微服务网关 ----- Nginx 和 Zuul 的区别
    Spring AOP SpringBoot集成
    Spring AOP 面向切面编程入门
    Vue中$refs与$emit的区别及使用场景实例
  • 原文地址:https://www.cnblogs.com/Iqiaoxun/p/5350586.html
Copyright © 2011-2022 走看看