System.currentTimeMillis()
获取的是当前时刻距离 1970-1-1 00:00:00.000(0时区)
的毫秒数。注意
- 1970年1月1日0时0分0秒0毫秒,这个时刻是0时区的。不是东八区的
1970-1-1 00:00:00.000
- 表述上只是到达了0毫秒,但其实后续的值都是0,如
1970年1月1日0时0分0秒0毫秒0微秒0纳秒0皮秒0...
- 正因为该方法是当前时刻到0时区的毫秒数,所以在这里时刻,无论在哪个时区获取,值都是一样的(意思是不管你把操作系统的时区改成什么,在同一时刻获取的值都是绝对一样的)
package com.wyf.test.timezone.example00;
import java.time.ZoneId;
/**
* 本类用于测试,在同一时刻调用 System.currentTimeMillis(),不会因为你的时区不同而获取到不同的数值
*
* 测试方法:初始时区在上海,运行一次,得到时间戳1,接着切换操作系统的时区到东京,再运行一次,得到时间戳2。时间戳2和时间戳1的差值,是你切换时区的耗时。
*
* 结论:可以看到耗时远远没有达到两个时区的差值1小时(差值仅仅是你切换OS的时区的手速)。说明无论你在什么时区,同一时刻获取的 System.currentTimeMillis() 的值是一样的
*
* 实验值:
* OSTimezone: Asia/Shanghai,timestamp: 1582855042967
* OSTimezone: Asia/Tokyo,timestamp: 1582855047352
*
* long millisSec = 1582855047352L - 1582855042967L;
* System.out.println("相差毫秒数:" + millisSec + ",秒数:" + (millisSec / 1000));
* 打印:相差毫秒数:4385,秒数:4
*
* @author Stone
* @version V1.0.0
* @date 2020/2/27
*/
public class TestSystemCurrentTimeMillis {
public static void main(String[] args) throws InterruptedException {
long timestamp = System.currentTimeMillis();
System.out.println("OSTimezone: " + ZoneId.systemDefault() + ",timestamp: " + timestamp);
}
}