静态代理和动态代理

静态代理(依旧是new对象,只不过加了一个中间对象):

https://blog.csdn.net/slhnl/article/details/119802015

动态代理(反射):

被代理的类需要实现接口!

 

接口

package day14;

public interface ITestDemo {
	void test1();
	void test2();
}

需要被代理的实现类

package day14;

public class TestDemoImpl implements ITestDemo {
	@Override
	public void test1() {
		System.out.println("执行test1()方法");
	}
	@Override
	public void test2() {
		System.out.println("执行test2()方法");
	}
}

实现InvocationHandler的动态代理类【需修改】

package day14;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;

/**
 * 动态代理类
 * @author Cjin
 */
public class ProxyDemo implements InvocationHandler{

	Object obj;//被代理的对象
	
	public ProxyDemo(Object obj){
		this.obj = obj;
	}
	
	@Override
	public Object invoke(Object proxy, Method method, Object[] args)
			throws Throwable {
		System.out.println(method.getName() + " 方法开始执行");
               //执行的是指定代理对象的指定的方法
		Object result = method.invoke(this.obj, args);
		System.out.println(method.getName() + " 方法执行完毕");
		return result;
	}
}

测试类

package day14;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Proxy;

public class Test1动态代理 {
	public static void main(String[] args) {
		ITestDemo test = new TestDemoImpl();
		test.test1();
		test.test2();
		System.out.println("======================");
 

		InvocationHandler handler = new ProxyDemo(test);
  // 3个参数,handler的类加载器,被代理类的接口,handler
		ITestDemo t = (ITestDemo)Proxy.newProxyInstance(handler.getClass().getClassLoader(), test.getClass().getInterfaces(), handler);
		
		t.test1();
		System.out.println("-----------------------");
		t.test2();
		
	}
}

测试结果image

posted @ 2022-08-19 20:09  2337  Views(15)  Comments(0Edit  收藏  举报