这几天温习了一下关于 java 反射 的内容,
发现JAVA 提供了 动态代理 的 默认实现(以前没用到过),
主要由 Proxy
类,InvocationHandler
接口(在 java.lang.reflect 包中)组成。
下面 演示一个使用 Proxy
和 InvocationHandler
类实现动态代理 的例子,
这个动态代理 对 被代理对象的方法执行时间进行计时,并将执行时间打印输出到控制台。
1,被代理类 的接口 Proxied
// 被代理类 需实现的 接口
public interface Proxied {
void doSomething();
void doSomethingElse(String str);
}
2,一个 Proxied接口 的实现类(被代理类)
public class ConcreteProxied implements Proxied {
@Override
public void doSomething() {
try {
Thread.sleep(100);
} catch (InterruptedException e) {
System.err.println("Error : InterruptedException");
}
System.out.println(this.getClass().getSimpleName()
+ " >> doSomething .");
}
@Override
public void doSomethingElse(String str) {
try {
Thread.sleep(150);
} catch (InterruptedException e) {
System.err.println("Error : InterruptedException");
}
System.out.println(this.getClass().getSimpleName()
+ " >> doSomethingElse , argument = " + str + ".");
}
}
3,TimingInvocationHandler 类,实现了 InvocationHandler 接口
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
public class TimeingInvocationHandler implements InvocationHandler{
//被代理的对象
private Object proxied;
public TimeingInvocationHandler(Object proxied){
this.proxied = proxied;
}
// 参数 proxy 表示代理类的对象
// 参数 method 表示被代理类 和 代理类 都实现的接口 的方法对象
// 参数 args 表示方法 method 的参数数组
@Override
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
System.out.println(method.getDeclaringClass().getName());
long currentTimeMillis = System.currentTimeMillis();
Object ret = method.invoke(proxied, args);
System.out.println(this.getClass().getSimpleName()+" >> wastes time : "
+(System.currentTimeMillis() - currentTimeMillis)+"ms");
return ret;
}
}
4,测试类 Test
import java.lang.reflect.Proxy;
public class TestProxy {
public static void main(String[] args) {
Proxied proxied = new ConcreteProxied();
proxied.doSomething();
proxied.doSomethingElse("only a String");
// 生成一个代理实例,这个代理实现了 Proxied 接口
// 对这个代理(proxy)的方法的调用 会 重定向到 TimeingInvocationHandler 的 invoke 方法
Proxied proxy = (Proxied) Proxy.newProxyInstance(Proxied.class
.getClassLoader(), // 类加载器
new Class[] { Proxied.class }, // 代理要实现的接口
new TimeingInvocationHandler(proxied) // 调用处理器
);
proxy.doSomething();
proxy.doSomethingElse("only a String");
}
}
运行Test类,输出如下:
ConcreteProxied >> doSomething .
ConcreteProxied >> doSomethingElse , argument = only a String.
ConcreteProxied >> doSomething .
TimeingInvocationHandler >> wastes time : 93ms
ConcreteProxied >> doSomethingElse , argument = only a String.
TimeingInvocationHandler >> wastes time : 157ms
分享到:
相关推荐
### Java中动态代理的核心知识点详解 #### 一、动态代理概览 动态代理是Java反射机制的一个重要应用,主要用于在不修改目标对象源代码的情况下,为一个对象提供一个代理对象,这个代理对象能够控制对目标对象的...
Java动态代理是Java编程中一个重要的特性,它允许我们在运行时创建代理对象,这些代理对象可以作为原有对象的“中间人”,在调用原有方法前或后执行额外的操作,如日志记录、性能监控、事务管理等。动态代理在很多...
下面我们将详细探讨Java动态代理及其在Spring AOP中的应用。 首先,我们来看动态代理的基本概念。在Java中,动态代理主要通过`java.lang.reflect.Proxy`类和`java.lang.reflect.InvocationHandler`接口来实现。`...
在Java中,动态代理和反射技术是两个非常重要的概念,它们在实际开发中有着广泛的应用。动态代理允许我们在运行时创建代理类,而反射则可以让我们在运行时检查和操作类、接口、字段以及方法。 首先,代理模式是一种...
1:静态代理出现的实际背景,静态代理时如何演化成动态代理 2: 动态代理demo 举例实际应用场景(载入数据库驱动的时候,使用AIDL与系统Servic进行通信) 3: 动态代理使用到基础理论:ClassLoader 加载.class字节码...
主要讲述Java反射机制与设计模式之一:代理模式的原理与应用;同时详细讲述了Java对代理模式的支持以及Java中动态代理的原理,应用与实践。
在Java动态代理中,我们首先需要定义一个或多个接口。这些接口定义了原始对象(也称为目标对象)所实现的方法。代理对象将实现这些接口,并在调用这些方法时执行额外的操作。 3. **InvocationHandler接口** `...
在Java中,动态代理主要通过`java.lang.reflect.Proxy`类和`java.lang.reflect.InvocationHandler`接口来实现。Proxy类是用于创建一个代理对象,而InvocationHandler接口则定义了代理对象调用方法时的行为。 1. **...
3. **拦截器模式**:在Java动态代理中,我们可以使用`InvocationHandler`来实现拦截器。拦截器是一种设计模式,它允许我们在方法调用前后插入自定义的代码,比如事务管理、权限检查等。通过动态代理,我们可以轻松地...
在静态代理中,我们通过编写额外的代理类来实现这一目标,但在动态代理中,代理类是在运行时生成的,无需预先编写代码。 Java JDK提供了`java.lang.reflect.Proxy`类和`java.lang.reflect.InvocationHandler`接口,...
动态代理分为两类:基于接口的代理(Java动态代理)和基于具体类的代理(CGLIB)。本文主要介绍基于接口的Java动态代理。 #### 二、Java动态代理机制 Java动态代理主要依赖于`java.lang.reflect.Proxy`类和`java....
Java动态代理技术是Java编程中一个非常重要的特性,它允许我们在运行时动态创建具有特定行为的对象。这种技术常用于AOP(面向切面编程)和框架中,如Spring AOP,用于实现方法拦截、事务管理等功能。Java提供了两种...
Java提供了两种主要的代理实现方式:静态代理和动态代理。 **静态代理** 静态代理是程序员手动创建代理类并实现与目标对象相同的接口。代理类和目标类都必须实现相同的接口,这样代理类就可以在调用目标对象方法的...