A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© HAnG 中级黑马   /  2013-12-19 15:29  /  843 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 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毫秒内调用完,还是写错了= =
求大神解答

评分

参与人数 1技术分 +1 收起 理由
乔兵 + 1

查看全部评分

4 个回复

倒序浏览
在中间加一个sleep()方法,让代码运行延迟几秒再试试不呗
回复 使用道具 举报
刘松703 发表于 2013-12-19 15:38
在中间加一个sleep()方法,让代码运行延迟几秒再试试不呗

sleep多久就打印多久了,看来还是CPU太快了= =  我这问题好像问得挺无聊的
回复 使用道具 举报
试试 System.nanoTime();  
可能是粒度的问题,毕竟System.currentTimeMillis()只是毫秒级的

评分

参与人数 1黑马币 +10 收起 理由
HAnG + 10 赞一个!

查看全部评分

回复 使用道具 举报
小骗子 发表于 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
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马