码迷,mamicode.com
首页 > 其他好文 > 详细

动态代理_基础版

时间:2019-04-09 11:07:41      阅读:228      评论:0      收藏:0      [点我收藏+]

标签:imp   基础   文件   src   例子   load   interface   tin   str   

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

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

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

技术图片

 

所谓动态代理,是 当 .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";
	}

	
}

 

//3.动态生成代理对象
package com.itheima.proxy;

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

import org.junit.Test;

public class ProxyTest {

	@Test
	public void test1() {
		// 获得动态的代理对象----在运行时 在内存中动态的为Target创建一个虚拟的代理对象
		// objProxy是代理对象 根据参数确定到底是谁的代理对象
		TargetInterface objProxy = (TargetInterface) Proxy.newProxyInstance(Target.class.getClassLoader(), // 与目标对象相同的类加载器
				new Class[] { TargetInterface.class }, new InvocationHandler() {
					// invoke 代表的是执行代理对象的方法
					@Override
					// method:代表目标对象的方法字节码对象
					// args:代表目标对象的响应的方法的参数
					public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
						System.out.println("目标方法前的逻辑");
						// 通过反射执行目标对象的方法
						Object invoke = method.invoke(new Target(), args);
						System.out.println("目标方法后的逻辑");
						return invoke;
					}
				});

		objProxy.method1();
		String method2 = objProxy.method2();
		System.out.println(method2);

	}

}

 

动态代理_基础版

标签:imp   基础   文件   src   例子   load   interface   tin   str   

原文地址:https://www.cnblogs.com/houchen/p/10675488.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!