动态代理

本文介绍了一个使用Java动态代理实现的具体示例。通过实现InvocationHandler接口并利用Proxy类创建代理对象,可以在目标方法调用前后添加自定义逻辑。这种方式避免了传统静态代理中对接口的直接实现,提供了一种更为灵活的代理解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package dynaticproxy;


import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;


public class Ruint implements InvocationHandler{

private Object any_Object;


@Override
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
Object return_object = null;
System.out.println("打印开始。。。。。。。。。。。。。。");
return_object = method.invoke(any_Object, args);
System.out.println("打印结束。。。。。。。。。。。。。。。");
return return_object;
}

public Object bind(Object object){
this.any_Object = object;
/*
* 这里用到了this对象,也就是InvocationHandler的对象(包含invoke方法 的对象 );
* proxy是一个代理类,它不像静态代理那样去实现接口,而是通过一个方法把接口传进去,也相当于实现了接口(怎么实现的看jdk的源码),在传进去  * 一个添加业务处理方法的

* 实现InvocationHandler接口的对象。(内部怎样调用invoke方法的看源码)。

 *  可以把 实现InvocationHandler 接口的对象和proxy    new 的实例分开写,分开写需要自己写得到 method类的方法。。。。

*/
return Proxy.newProxyInstance(any_Object.getClass().getClassLoader(),      
any_Object.getClass().getInterfaces(), this);  
}

public static void main(String[] args) {
Hello_interface_impl  h1 = new Hello_interface_impl();
Ruint r = new Ruint();    /// 处理类
Hello_interface h2 = (Hello_interface)r.bind(h1);
h2.say_hello();

}


}


interface Hello_interface {
public void say_hello();
}


class Hello_interface_impl implements Hello_interface{


@Override
public void say_hello() {
System.out.println("......hello....");

}

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值