1、java自带的proxy类可以创建动态类,如果一个类实现了一个接口那么久可以为这个类创建代理。
2、代理:就是当用户要调用一个类的方法时,用户可以通过调用代理,代理通过接口调用原来的类的方法,代理在把方法给用户前可以添加一些方法,如错误日志,用户类的方法运行的时间来监听类方法的性能。当代理完成时候就是当代理调用方法时候,就会启动InvocationHandler里的invoke方法。用户并不知道用户要为哪个类带理,因此在框架中用配置文件来获取代理的类,用户需要用框架时候就修改配置文件即可。
public class Proxydemo {public static void main(String[] args) throws Exception {//这是分2部,来实现collection的代理的,下面是1步实现代理,并且是任何类
// Class classproxy=Proxy.getProxyClass(Collection.class.getClassLoader(),Collection.class);
// Constructor[]constructors=classproxy.getConstructors();
// Constructor constructor=classproxy.getConstructor(java.lang.reflect.InvocationHandler.class);
// for(Constructor c:constructors)
// {
// System.out.println(c.toString());
// }final ArrayList a=new ArrayList<>();
// Collection c=(Collection) constructors[0].newInstance(new InvocationHandler(){
//
// @Override
// public Object invoke(Object proxy, Method method, Object[] args)
// throws Throwable {
// ArrayList a=new ArrayList<>();
// System.out.println(System.currentTimeMillis());
// Object ob=method.invoke(a ,args);
// System.out.println("a的size:"+a.size());
// System.out.println(System.currentTimeMillis());
// return ob;
// }
//
// });c.add("dada"); c.add("dada");System.out.println( c.size());
// //下面是实现代理的原理,pr是给代理的接口,advice是代理要监控方法的接口final Pro pr=new ProtexTest();final Advice advice=new MyAdvice();Pro classproxy=(Pro)Proxy.newProxyInstance(pr.getClass().getClassLoader(), new Class[]{Pro.class}, new InvocationHandler(){@Overridepublic Object invoke(Object proxy, Method method, Object[] args)throws Throwable {advice.beforemethod();//这是方法前调用的方法Object o=method.invoke(pr, args);advice.aftermethod();//这是方法后调用的方法return o;}});
//当调用sayhello时候,系统就去找代理调用InvocationHandler里的invoke方法。classproxy.sayhello();
/* 所以打印结果为:1441522392491hello1441522392493
*/ //调用代理函数Pro o=(Pro) daili(pr,advice);o.sayhello();}/******************下面可以吧上面的方法抽出为一个代理方法,为任何实现接口的类代理*****//** target 为目标类实现的接口* advice为代理要监控方法的接口*/public static Object daili(final Object target,final Advice advice){Object classproxy=(Object)Proxy.newProxyInstance(target.getClass().getClassLoader(),target.getClass().getInterfaces(), new InvocationHandler(){@Overridepublic Object invoke(Object proxy, Method method, Object[] args)throws Throwable {advice.beforemethod();//这是方法前调用的方法Object o=method.invoke(target, args);advice.aftermethod();//这是方法后调用的方法return o;//返回方法执行后返回的值}});return classproxy;}
}