Java精确测量代码运行时间 代码执行时间 纳秒 nanoTime
2014-03-14 09:54
525 查看
Java精确测量代码运行时间:
long startTime = System.nanoTime(); //開始時間 for(int i = 0;i<10000;i++){ ; } long consumingTime = System.nanoTime() - startTime; //消耗時間 System.out.println(consumingTime); System.out.println(consumingTime/1000+"微秒");
JDK的解释:
public static long nanoTime()
Returns the current value of the most precise available system timer, in nanoseconds.
This method can only be used to measure elapsed time and is not related to any other notion of system or wall-clock time. The value returned represents nanoseconds since some fixed but arbitrary time (perhaps in the future, so values may be negative). This method provides nanosecond precision, but not necessarily nanosecond accuracy. No guarantees are made about how frequently values change. Differences in successive calls that span greater than approximately 292 years (263 nanoseconds) will not accurately compute elapsed time due to numerical overflow.
For example, to measure how long some code takes to execute:
long startTime = System.nanoTime(); //開始時間 for(int i = 0;i<10000;i++){ ; } long consumingTime = System.nanoTime() - startTime; //消耗時間 System.out.println(consumingTime); System.out.println(consumingTime/1000+"微秒");
JDK的解释:
public static long nanoTime()
Returns the current value of the most precise available system timer, in nanoseconds.
This method can only be used to measure elapsed time and is not related to any other notion of system or wall-clock time. The value returned represents nanoseconds since some fixed but arbitrary time (perhaps in the future, so values may be negative). This method provides nanosecond precision, but not necessarily nanosecond accuracy. No guarantees are made about how frequently values change. Differences in successive calls that span greater than approximately 292 years (263 nanoseconds) will not accurately compute elapsed time due to numerical overflow.
For example, to measure how long some code takes to execute:
long startTime = System.nanoTime(); // ... the code being measured ... long estimatedTime = System.nanoTime() - startTime;
相关文章推荐
- spring详解
- Java基础
- java识别文件或字符串的编码格式
- (转)Java身份证工具类
- java.util.concurrent.CountDownLatch组件说明
- myeclipse不编译解决方法
- Java数组排序Arrays.sort
- 在Eclipse中关联源代码
- 用JAVA实现一个简单地Socket服务器,可以实现发给指定对象
- Eclipse is running in a JRE, but a JDK is required
- Java I/O流常用类小结
- Java Enum implementing an Interface
- MyEclipse6.5上安装maven插件
- JAVA在线观看视频教程完整版
- MyEclipse遇到的一些问题解决办法
- Java设计模式之装饰者模式
- java中List集合迭代
- Java时间格式的相互转换
- java中使用二进制进行权限控制
- java的HashCode方法