Java中更精确的计时

我们一般的java运输计时代码是

 

1 long begintime = System.currentTimeMillis();
2 
3 //运算代码
4 
5 long endtinme=System.currentTimeMillis();
6 
7 long costTime = (endtime - begintime);

 

 

但是,如果运算时间很短的时候,这个一个是现在机器太厉害,还有由于.currentTimeMillis()是1970年1月1日到现在的毫秒数,估计应该把很多小数位省略了,没看过代码,猜的,呵呵。结果一般是0,无法显示算法消耗时间,这个时候可以用nanoTime(),纳秒。

 

1 long begintime = System.nanoTime();
2 
3 //运算代码
4 
5 long endtime = System.nanoTime();
6 long costTime = (endtime - begintime)/1000;
7 
8 //要换算为微秒,就除上1000,就可以

 

posted on 2016-09-22 14:10  允我心安  阅读(16334)  评论(1编辑  收藏  举报