1、Java的动态代理对象:本质是一种包装设计模式(特点:不修改源码的情况下,增强某个方法的功能)
应用案例:JDBC的数据库的连接池(DataSource)
1、首先定义接口
2、定义接口的实现类
3、创建真正对象和代理对象,并用代理对象去实现增强功能方法
==================================================================
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、创建真正对象和代理对象,并用代理对象去实现增强功能方法
package demo.proxy.java;
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;
public class TestMain {
public static void main(String[] args) {
//创建真正的对象
final MyService obj = new MyServiceImpl();
//这种方式是直接调用真正的对象
//obj.method1();
//生成obj真正对象的代理对象
/*
* Object Proxy.newProxyInstance(ClassLoader loader, 类加载器,使用当前类的加载器
Class<?>[] interfaces, 真正对象实现的接口
InvocationHandler h) 如何在代理对象中处理客户端调用
需求:重写method1实现
*/
MyService proxy = (MyService) Proxy.newProxyInstance(TestMain.class.getClassLoader(),
obj.getClass().getInterfaces(),
new InvocationHandler() {
@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();
}
}