System.currentTimeMillis()
静态方法System.currentTimeMillis()返回1970-01-01 00:00:00.000到现在的毫秒数,返回值是一个long型
- long timeNow = System.currentTimeMillis();
- long timeNow = System.currentTimeMillis();
- java.util.Date uDate = new java.util.Date(timeNow);
- System.out.println(uDate.toString());
- java.sql.Date sDate = new java.sql.Date(timeNow);
- System.out.println(sDate.toString());
- Time time = new Time(timeNow);
- System.out.println(time.toString());
- Timestamp timestamp = new Timestamp(timeNow);
- System.out.println(timestamp.toString());
System.nanoTime()
顺便说一下System.nanoTime(),这也是一个静态方法,获得一个以纳秒为单位的值。但是它和日期或时间的表示没有任何关系,不要将它和当前的日期或时间联系起来。在上面我们看到System.currentTimeMillis()返回的是1970-01-01 00:00:00.000到现在的毫秒数,但System.nanoTime()返回的不是1970-01-01 00:00:00.000到现在的纳秒数,这个计时开始时间是不确定的。
- //如果System.nanoTime()和当前时间有关系,那millis应该和当前毫秒数近似相等
- long millis = System.nanoTime()/1000;
- java.util.Date date = new java.util.Date(millis);
- /*
- * 但这个date的值明显和当前日期差距甚大,而且每次启动jvm运行都不一样
- * 说明System.nanoTime()的开始计时时间并不是一个固定值
- */
- System.out.println(date.toString());
- long startTime = System.nanoTime();
- // ... the code ...
- long estimatedTime = System.nanoTime() - startTime;
以上这段程序在大多数情况下可以得到我们期望的结果,但也有例外,例如在window xp系统中可能会出现负值。
至于为什么出现负值,网上有资料说和CPU和操作系统都有关系,由于本人理解也很局限,不妄下定论,有兴趣的同学可以研究一下