打字猴:1.700461181e+09
1700461181
1700461182 ClassLoader loader=subject.getClass().getClassLoader();
1700461183
1700461184 //获得接口数组
1700461185
1700461186 Class<?>[]classes=subject.getClass().getInterfaces();
1700461187
1700461188 //获得handler
1700461189
1700461190 InvocationHandler handler=new MyInvocationHandler(subject);
1700461191
1700461192 return newProxyInstance(loader,classes,handler);
1700461193
1700461194 }
1700461195
1700461196 }
1700461197
1700461198 如此扩展以后,高层模块对代理的访问会更加简单,如代码清单12-32所示。
1700461199
1700461200 代码清单12-32 场景类
1700461201
1700461202 public class Client{
1700461203
1700461204 public static void main(String[]args){
1700461205
1700461206 //定义一个主题
1700461207
1700461208 Subject subject=new RealSubject();
1700461209
1700461210 //定义主题的代理
1700461211
1700461212 Subject proxy=SubjectDynamicProxy.newProxyInstance(subject);
1700461213
1700461214 //代理的行为
1700461215
1700461216 proxy.doSomething(“Finish”);
1700461217
1700461218 }
1700461219
1700461220 }
1700461221
1700461222 是不是更加简单了?可能读者就要提问了,这样与静态代理还有什么区别?都是需要实现一个代理类,有区别,注意看父类,动态代理的主要意图就是解决我们常说的“审计”问题,也就是横切面编程,在不改变我们已有代码结构的情况下增强或控制对象的行为。
1700461223
1700461224 注意 要实现动态代理的首要条件是:被代理类必须实现一个接口,回想一下前面的分析吧。当然了,现在也有很多技术如CGLIB可以实现不需要接口也可以实现动态代理的方式。
1700461225
1700461226 再次说明,以上的动态代理是一个通用代理框架。如果你想设计自己的AOP框架,完全可以在此基础上扩展,我们设计的是一个通用代理,只要有一个接口,一个实现类,就可以使用该代理,完成代理的所有功效。
1700461227
1700461228
1700461229
1700461230
[ 上一页 ]  [ :1.700461181e+09 ]  [ 下一页 ]