java反射机制学习(六):动态代理

1、普通的静态代理

//接口
interface Subject{
	public String say(String name,int age);
}

//实际实现类
class RealSubject implements Subject{
	public String say(String name,int age){
		return "姓名:"+name+",年龄:"+age;
	}
}

//静态代理类
class ProxySubject implements Subject{
	private Subject sub=null;
	//构造方法
	public ProxySubject(Subject sub){
		this.sub=sub;
	}
	//调用“真实方法”进行处理
	public String say(String name,int age){
		return this.sub.say(name, age);
	}
}

//main方法进行测试
public class DynaProxyDemo {
	public static void main(String[] args){
		//测试静态代理
		Subject sub = new ProxySubject(new RealSubject());//调用代理类
		String result = sub.say("wjl",123);
		System.out.println(result);
	}
}

静态代理存在的一个问题:一个代理类只能为一个接口服务,如果有很多个接口的话就需要很多个代理类。而且所有的代理除了调用的方法不一样之外其他的都是一样的,必然出现代码重复的问题。

2、动态代理

在原来的基础上添加动态代理类:

class MyInvocationHandler implements InvocationHandler{
	private Object realObj = null;//真实主题
	public Object bind(Object obj){//实例化真实主题
		this.realObj = obj;
		//实例化代理类
		//newProxyInstance(ClassLoader loader,Class<?> interfaces,InvocationHandler h):
		//loader:类加载器
		//interfaces:得到全部的接口
		//h:得到InvocationHandler接口的子类实例
		return Proxy.newProxyInstance(realObj.getClass().getClassLoader(), realObj.getClass().getInterfaces(), this);
	}
	
	public Object invoke(Object proxy, Method method, Object[] args)
			throws Throwable {
		//invoke(Object proxy,Method method,Object args[]):
		//proxy:被代理的对象
		//method:要调用的方法
		//args[]:方法调用时所需要的参数
		Object tempObj = method.invoke(this.realObj, args);
		return tempObj;
	}
}

//main方法测试
public class DynaProxyDemo {
	public static void main(String[] args){		
		//测试动态代理
		Subject sub2 = (Subject)new MyInvocationHandler().bind(new RealSubject());
		String result2 = sub2.say("admin",123456);
		System.out.println(result2);
	}
}

  

猜你喜欢

转载自1017401036.iteye.com/blog/2343717
今日推荐