java visualvm分析_分析-Java VisualVM中的方法总时间

Javassist是一个类库,可以在不接触源代码的情况下操纵您的Java字节码。 让我们举一个例子来衡量执行一个方法所花费的时间。

public class Subject {

/**

* Timetaken for start & end of the method

*

* @throws InterruptedException

*/

public void method2() throws InterruptedException {

// Some business logic :)

Thread.sleep(2000);

}

}

要测量执行subject.method2()所花费的时间,可以通过添加所示方法的代码开头和结尾来增强Subject.methods()。

public class JavaAssist {

public static void main(String[] args) {

timeTaken();

}

public static void timeTaken() {

try {

ClassPool p = ClassPool.getDefault();

CtClass cc = p.get("Subject");

CtMethod meth2 = cc.getDeclaredMethod("method2");

meth2.insertBefore("System.out.println(\" Start : \"+new java.util.Date());");

meth2.insertAfter("System.out.println(\" End : \"+new java.util.Date());");

// cc.writeFile(".");

Class c = cc.toClass();

Subject s = (Subject) c.newInstance();

s.method2();

cc.detach();

} catch (Exception e) {

// suppressed

}

}

}

输出:开始时间:美国东部时间2010年5月26日星期三17:24:18完:美国东部夏令时间2010年5月26日星期三17:24:20

参考[http://www.csg.is.titech.ac.jp/~chiba/javassist/tutorial/tutorial.html#read]

[http://www.csg.is.titech.ac.jp/~chiba/javassist/html/]

发件人来源:[http://www.senthilb.com/2010/05/javaassist-byte-code-enhancement.html]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值