动态代理_基础版

动态代理_基础版

在介绍动态代理之前首先简单捎带下静态代理(自己的理解)

所谓静态代理是实际调用者通过一个代理对象调用目标对象的方法,代理对象与目标对象必须具备相同的方法名,

所以代理对象和目标对象必须实现同一个接口。静态代理的缺点是:开发者必须自己手动实现 代理类

所谓动态代理,是 当 .java源码通过类加载器变成字节码文件时,在内存中动态生成目标对象的代理对象。

开发人员不需要自己定义代理类。(下面举个例子,给出实现动态代理的代码)

//1.目标对象和代理对象实现的接口
package com.itheima.proxy;

public interface TargetInterface {
	public void method1();
	public String method2();
}
//2.目标对象
package com.itheima.proxy;

public class Target implements TargetInterface{

	@Override
	public void method1() {
		System.out.println("method1 running...");
	}

	@Override
	public String method2() {
		System.out.println("method2 running...");
		return "method2";
	}

	
}

Proxy.newProxyInstance()  api各个参数的解析

//3.动态生成代理对象
package com.itheima.proxy; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; public class ProxyTest2 { public static void main(String[] args) { final Target target = new Target(); //动态创建代理对象 TargetInterface proxy = (TargetInterface) Proxy.newProxyInstance( target.getClass().getClassLoader(), //目标对象 类的加载器 target.getClass().getInterfaces(), // 代理对象实现的 接口calss文件的数组 new InvocationHandler() { @Override //被执行几次?------- 看代理对象调用方法几次 //代理对象调用接口相应方法 都是调用invoke /* * proxy:是代理对象 * method:代表的是目标方法的字节码对象 * args:代表是调用目标方法时参数 */ public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { //反射知识点 Object invoke = method.invoke(target, args);//目标对象的相应方法 //retrun返回的值给代理对象 return invoke; } } ); proxy.method1();//调用invoke---Method:目标对象的method1方法 args:null 返回值null String method2 = proxy.method2();//调用invoke---Method:目标对象的method2方法 args:null 返回值method2 int method3 = proxy.method3(100);////调用invoke-----Method:目标对象的method3方法 args:Object[]{100} 返回值100 System.out.println(method2); System.out.println(method3); } }
 
posted @ 2019-04-09 10:41 林汐------ 阅读( ...) 评论( ...) 编辑 收藏

猜你喜欢

转载自blog.csdn.net/hc1285653662/article/details/89168613