对TProfile (https://github.com/taobao/TProfiler)产生了兴趣,于是就下下来研究了一下:
非常简单小巧,代码质量也很高,最多20个class。其实现的核心原理就是利用javaAgent,在premain函数中使用java.lang.instrument.ClassFileTransformer,对允许采样的类生成org.objectweb.asm.ClassAdapter
再利用org.objectweb.asm.MethodAdapter的visitXXX 系列(对应功能可到这里查:http://t.cn/SqTMQM),注入采样代码,如下
注入方法开始时的采样代码
注入方法结束时的采样代码
visitInsn指的是执行单条指令时需要执行的勾子。
其实关于这种通过字节码注入方式实现性能监测的方法,IBM还有专门的一篇文档介绍:
http://www.ibm.com/developerworks/cn/java/j-jip/#resources