您当前的位置: 首页 > 

石头wang

暂无认证

  • 5浏览

    0关注

    295博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

关于System.currentTimeMillis()的理解

石头wang 发布时间:2020-02-28 10:23:55 ,浏览量:5

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); } }

关注
打赏
1663722529
查看更多评论
立即登录/注册

微信扫码登录

0.0376s