黑马程序员技术交流社区

标题: 一点疑问 [打印本页]

作者: HAnG    时间: 2013-12-19 15:29
标题: 一点疑问
本帖最后由 HAnG 于 2013-12-19 15:47 编辑
  1. new InvocationHandler(){  
  2.         Collection  target = new ArrayList();
  3.         @Override  
  4.         public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {  
  5.                 long startTime = System.currentTimeMillis();
  6.                 Object result = method.invoke(target, args);
  7.                 long endTime = System.currentTimeMillis();
  8.                 System.out.println(method.getName() + " run for " + (endTime - startTime) + "ms");
  9.                 return result;
  10.         }     
  11. }  
复制代码


动态代理中,在invoke方法里加入运行时间功能。
运行结果为什么调用每个函数运行时间都是0ms,是我的CPU真有这么快在1毫秒内调用完,还是写错了= =
求大神解答

作者: 刘松703    时间: 2013-12-19 15:38
在中间加一个sleep()方法,让代码运行延迟几秒再试试不呗
作者: HAnG    时间: 2013-12-19 15:47
刘松703 发表于 2013-12-19 15:38
在中间加一个sleep()方法,让代码运行延迟几秒再试试不呗

sleep多久就打印多久了,看来还是CPU太快了= =  我这问题好像问得挺无聊的
作者: 小骗子    时间: 2013-12-19 19:06
试试 System.nanoTime();  
可能是粒度的问题,毕竟System.currentTimeMillis()只是毫秒级的


作者: HAnG    时间: 2013-12-19 20:15
小骗子 发表于 2013-12-19 19:06
试试 System.nanoTime();  
可能是粒度的问题,毕竟System.currentTimeMillis()只是毫秒级的

这个很赞!纳秒级!
add run for 136584纳秒
add run for 4359纳秒
add run for 3269纳秒
remove run for 9444纳秒
toString run for 54125纳秒
[heima, cbh]
size run for 9081纳秒
2




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2