java静态代理没什么好说,所谓的代理 就是一种中介。假如你在java里面有个接口的方法要拓展,但是你又不想在这个方法里面去改原先的逻辑,为了保证系统的可维护性。你可以通过这种代理的方式,类似于spring的aop面向切面编程。静态代理的局限性每次都创建一个静态代理类,假如有100个接口要代理,就要创建100个静态代理类,很麻烦。直接通过java反射的方式去动态代理。
创建一个要代理的接口
package com.cn.reflection;
/**
* Created by ZC-16-012 on 2018/11/5.
* 动态代理的接口
*/
public interface Person {
void walk();
void sayHello(String name);
}
package com.cn.reflection;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
/**
* Created by ZC-16-012 on 2018/11/5.
*/
public class MyInvoketionHandle implements InvocationHandler {
/**
* @param proxy 动态代理对象
*@param method 代表正在执行的方法
* @param args 代表调用目标方法时传入的实参
* */
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
System.out.println("---正在执行的方法:"+method);
if (args!=null){
System.out.println("下面是执行该方法时传入的实参:");
for (Object arg :args){
System.out.println(arg);
}
}else {
System.out.println("调用的方法没有实参!");
}
return null;
}
}
package com.cn.reflection;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Proxy;
/**
* Created by ZC-16-012 on 2018/11/5.
* 动态代理代码测试
*/
public class ProxyTest {
public static void main(String[] args){
InvocationHandler handler= new MyInvoketionHandle();
Person p= (Person) Proxy.newProxyInstance(Person.class.getClassLoader(),new Class[]{Person.class},handler);
p.walk();
p.sayHello("hello world");
}
}
如图运行结果如下:
可以在invoke()去拓展功能了。