动态代理

动态代理

  • 目的:完成代码的增强
  • 个人理解:代理类在程序运行时创建的代理方式被成为动态代理。 我们上面静态代理的例子中,代理类(studentProxy)是自己定义好的,在程序运行之前就已经编译完成。然而动态代理,代理类并不是在Java代码中定义的,而是在运行时根据我们在Java代码中的“指示”动态生成的。相比于静态代理, 动态代理的优势在于可以很方便的对代理类的函数进行统一的处理,而不用修改每个代理类中的方法。
  • 接口类
package com.gaoji.member;
//接口类
public interface Person {
   
	void showName();
	void showAge();
	void showSex();
}

  • 实现类
package com.gaoji.member;
//实现类
public class PersonImpl implements Person{
   
    @Override
    public void showName() {
   
            // TODO Auto-generated method stub
            System.out.println("我叫张三");
    }
    @Override
    public void showAge() {
   
            // TODO Auto-generated method stub
            System.out.println("今年十八岁");
    }
    @Override
    public void showSex() {
   
            // TODO Auto-generated method stub
            System.out.println("我是男孩子");
    }
}

  • 代理类
package com.gaoji.member;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
import java.util.Date;
//代理类
public class InvocationHandlerImpl implements InvocationHandler{
   
    // 目标对象 
private Object target;  

/** * 构造方法 * @param target 目标对象 */  
public InvocationHandlerImpl(Object target) {
     
  super();  
  this.target = target;  
}  
/** * 获取目标对象的代理对象 * @return 代理对象 */  
public Object getProxy() {
     
  return Proxy.newProxyInstance(Thread.currentThread().getContextClassLoader(),   
          target.getClass().getInterfaces(), this);  
}


  @Override
  public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
   
             // 在目标对象的方法执行之前简单的打印一下 proxy:类加载器、method:接口
  System.out.println(method.getName()+"开始"+new Date());  
    
  
  // 执行目标对象的方法 
  Object result = method.invoke(target, args);  
    
  // 在目标对象的方法执行之后简单的打印一下 
  System.out.println(method.getName()+"结束了"+new Date());  
    
  return result;
  }  
}

  • 驱动类
package com.gaoji.member;
/*驱动类 * 高内聚,低耦合 1.非业务逻辑代码冗余 2.维护困难 */
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
//动态代理
// 项目测试时,需要日写志
public class MainTest {
   
	public static void main(String[] args) {
   
		/*Person p=new PersonImpl(); p.showName(); p.showAge();*/
		Person p=new PersonImpl();
		InvocationHandlerImpl handler =new InvocationHandlerImpl(p);
		Person p1=(Person) handler.getProxy();//代理类
		p1.showAge();
		p1.showName();
		p1.showSex();
	}
}

  • 结果
showAge开始Fri May 10 21:04:34 GMT+08:00 2019
今年十八岁
showAge结束了Fri May 10 21:04:34 GMT+08:00 2019
showName开始Fri May 10 21:04:34 GMT+08:00 2019
我叫张三
showName结束了Fri May 10 21:04:34 GMT+08:00 2019
showSex开始Fri May 10 21:04:34 GMT+08:00 2019
我是男孩子
showSex结束了Fri May 10 21:04:34 GMT+08:00 2019

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106725.html原文链接:https://javaforall.net

(0)
上一篇 2021年7月20日 下午8:00
下一篇 2021年7月20日 下午9:00


相关推荐

  • 关于数据库逻辑删除(伪删除)的设计方案探讨

    关于数据库逻辑删除(伪删除)的设计方案探讨项目上碰到过关于数据采用了逻辑删除导致的问题,情况是这样:原先的代码中,对于表T中的数据的删除采用的是逻辑删除,但是其他使用该数据的地方并没有针对逻辑删除进行配套的处理。该表T中存在字段A要求不能重复,其实就是说字段A是uniquekey。那么问题就来了,逻辑删除只是将数据的status字段更新为删除状态,所以字段A的旧值依然存在,导致插入新数据时,就不能使用已经删除的字段A的值,这明显是…

    2022年5月12日
    51
  • Android http Request / Response ContentType

    Android http Request / Response ContentType客户端在进行http请求服务器的时候,需要告诉服务器请求的类型,服务器在返回给客户端的数据的时候,也需要告诉客户端返回数据的类型。这个类型就是 ContentType ,不同的ContentType会影响客户端/服务器所看到的效果。contentType:告诉服务器,我要发什么类型的数据  1、默认的ContentType为 text/html也就是网页格式.   

    2022年7月19日
    13
  • 智能体性能测试:AI Agents for Beginners基准测试报告

    智能体性能测试:AI Agents for Beginners基准测试报告

    2026年3月16日
    2
  • js 数组分割

    js 数组分割lt DOCTYPEhtml gt lt htmllang en gt lt head gt lt metacharset UTF 8 gt lt metaname viewport content width device width initial scale 1 0 gt

    2026年3月17日
    2
  • pycharm自动导入包_python自动到包快捷键

    pycharm自动导入包_python自动到包快捷键在终端通过pip装好包以后,在pycharm中导入包时,依然会报错。新手不知道具体原因是什么,我把我的解决过程发出来。解决方案一:在Pycharm中,依次打开File—>Settings,弹窗如下图:点击右侧“+”号,输入自己需要导入包的名称,在下面列表中可以看到自己需要的包,详图如下:最后点击InstallPackage,等待安装完成即可。解决方案二:前提是已经在终端通过pipin…

    2022年8月28日
    4
  • 基于SAML的ADFS认证集成方案

    基于SAML的ADFS认证集成方案whyADFS 之所以和 ADFS sayhello 是公司要求 实现内网项目在外网下的 SSO 登录访问当第一次看到 ADFS 时 第一想到是公司内部哪个工程师搞得一个架构 取英文缩写 ADFS 大概用于身份认证 提到到认证方式 想到目前市面主流的 oauth2 Jwt OpenID 等 基于 SAML2 0 的 ADFS 服务器集成方案是啥 如果是内部框架也没有太详细的部署方案啊 去搜索 saml 概念 发

    2026年3月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号