快速业务通道

Java编程的动态性,第6部分: 利用Javassist进行面向方面的更改 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-17
if (args.length >= 1) {        try {          // set up class loader with translator          Translator xlat = new DissectionTranslator();          ClassPool pool = ClassPool.getDefault(xlat);          Loader loader = new Loader(pool);          // invoke the "main" method of the application  class          String[] pargs = new String[args.length-1];          System.arraycopy(args, 1, pargs, 0, pargs.length);          loader.run(args[0], pargs);        } catch (Throwable ex) {          ex.printStackTrace();        }      } else {        System.out.println          ("Usage: Dissect main-class args...");      }    }    public static class DissectionTranslator implements Translator    {      public void start(ClassPool pool) {}      public void onWrite(ClassPool pool, String cname)        throws NotFoundException, CannotCompileException {        System.out.println("Dissecting class " + cname);        CtClass clas = pool.get(cname);        clas.instrument(new VerboseEditor());      }    }    public static class VerboseEditor extends ExprEditor    {      private String from(Expr expr) {        CtBehavior source = expr.where();        return " in " + source.getName() + "(" +  expr.getFileName() + ":" +          expr.getLineNumber() + ")";      }      public void edit(FieldAccess arg) {        String dir = arg.isReader() ? "read" : "write";        System.out.println(" " + dir + " of " + arg.getClassName () +          "." + arg.getFieldName() + from(arg));      }      public void edit(MethodCall arg) {        System.out.println(" call to " + arg.getClassName() + "."  +          arg.getMethodName() + from(arg));      }      public void edit(NewExpr arg) {        System.out.println(" new " + arg.getClassName() + from (arg));      }    } }

Java编程的动态性,第6部分: 利用Javassist进行面向方面的更改(4)

时间:2011-04-09 IBM Dennis M. Sosnoski

清单 4 显示了对 清单 2 中的 BeanTest 程序运行清单 3 中的 Dissect 程序所产生的 输出。它给出了加载的每一个类的每一个方法中所做的工作的详细分析,列出了所有方法调用 、字段访问和新对象创建。

清单 4. 已剖析的 BeanTest

[dennis]$ java -cp .:javassist.jar Dissect BeanTest Dissecting class BeanTest   new Bean in BeanTest(BeanTest.java:7)   write of BeanTest.m_bean in BeanTest(BeanTest.java:7)   read of java.lang.System.out in print(BeanTest.java:11)   new java.lang.StringBuffer in print(BeanTest.java:11)   call to java.lang.StringBuffer.app

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号