-
代理类 ProxySubject 被代理类 RealSubject 加入了InvocationHandler 的ProxyHandler 事务处理器查看全部
-
、、、、、、、、、、、、查看全部
-
、、、、、、、、、、、、查看全部
-
、、、、、、、、、、、、、查看全部
-
动态代理查看全部
-
因为代理之间实现了相同的接口,他们之间是可以相互传递的,相互组合,更加灵活查看全部
-
/* * 仔细理解一下, 就是一层层嵌套叠加。。。 * 先调用ctp.move(); 输出 “汽车开始行驶...” * clp参数传到m.move方法;调用clp.move(),输出 “日志开始...” * car参数传到m.move方法;调用Car对象中的move方法。输出 “汽车行驶中....” * 然后调完clp.move()返回,输出 “日志结束...” * 调完返回ctp.move()返回,输出“汽车结束行驶... 汽车行驶时间: 毫秒” * */查看全部
-
实现功能的叠加,需要很多子类查看全部
-
继承方式和聚合方式都能实现静态代理,那种更适合???查看全部
-
AOP查看全部
-
设计理念查看全部
-
sysout+alt+/ 快捷键System.out.println();查看全部
-
动态代理的实现步骤查看全部
-
3、将这个类load到内存当中,产生一个新的对象(代理对象); //load到内存 ClassLoader cl = ClassLoader.getSystemClassLoader(); Class c = cl.loadClass(“com.imooc.proxy.$Proxy0”); Constructor ctr = c.getConstructor(infuse);//传入接口参数 ctr.newInstance();//产生代理类的对象 4、return代理对象。 JDK动态代理,只能代理实现了接口的类,没有实现接口的类不能实现JDK的动态代理。 CGLIB动态代理,针对类来实现代理,对指定目标类产生一个子类,通过方法拦截技术拦截所有父类方法的调用。查看全部
-
动态代理实现思路 实现功能:通过newProxyInstance返回代理对象, 1、声明一段源码(动态产生代理); 将源码注释掉存到一个str里; 可以创建事务处理器,动态处理业务逻辑,见3.3节; 写个继承自InvocationHandler的子类,将逻辑放在invoke方法中,两个参数(类对象和方法) 给newProxyInstance多一个参数InvocationHandler; 在str中还要把它的import引入加上。 2、编译源码(JDK Compile API),产生新的类(代理类); 通过java文件编译,String filename = System.getProperty(“user.dir”) + “/bin/com/imooc/proxy/$Proxy.java”; File file = new File(filename); 加入jar包,common-o.jar , 快速对文件进行读写删除操作。 FileUtils.writeStringToFile(file, str); 实现对任意对象任意接口。。。 //拿到编译器 JavaCompiler complier = ToolProvider.getSystemJavaCompiler(); //文件管理者 StandardJavaFileManager fileMgr = complier.getStandardFileManager(null,null,null);//diagnosticListener, locale,charset //获取文件 Iterable units = fileMgr.getJavaFileObjects(filename); //编译任务 CompilationTask t = complier.getTask(null, fileMgr, null,null,units); //进行编译 t.call(); fileMgr.close();查看全部
举报
0/150
提交
取消