1. Java的动态代理对象原理: 本质是一种包装设计模式(特点: 不修改源码的情况下,增强某个方法的功能)
a.图片形式:
b.代码:
(1).接口
package demo.proxy.java;
public interface MyService(){
//声明业务
public void method1();
public void method2();
}
(2). 实现接口
package demo.proxy.java;
public class MyServiceImpl implements MyService {
@Override
public void method1() {
System.out.println("************** method 1 **************");
}
@Override
public void method2() {
System.out.println("************** method 2 **************");
}
}
(3).代理
public class TestMain(){
//创建真正的对象
final MyService obj = new MyServiceImpl();
//这种方式是直接调用真正的对象
obj.method1();
//生成obj真正对象的代理对象
/*
*Object Proxy.newProxyInstance(ClassLOader loader, 类加载器,使用当前类的加载器
Class<?> interfaces, 真正对象实现的接口
InvocatinHandler h)如何在代理对象中处理客户端的调用
需求: 重写method1实现
*/
MyService proxy = (MyService) Proxy.newPaorxyInstance(TestMain.class.getClassLOader(),
obj.getClass().getInterfaces(),
new InvocationHander(){
@Override
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
//处理客户端的调用
if(method.getName().equals("method1")){
//调用了method1
System.out.println("******* in proxy: method1********");
return null;
}else{
//调用了其它方法,通过调用真正的对象去完成
return method.invoke(obj, args);
}
}
});
//通过代理对象去调用业务方法
proxy.method1();
proxy.method2(;)
}