博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Unix时间戳和Java中的时间戳的区别
阅读量:2197 次
发布时间:2019-05-02

本文共 1497 字,大约阅读时间需要 4 分钟。

前言

最近在使用阿里的日志服务时,遇到了一些JavaTimestamp的坑,所以特意做了了解并整理了一下。在这之前首先得介绍一下Unix时间戳:

Unix时间戳是从1970年1月1日(UTC/GMT的午夜)开始所经过的秒数,不考虑闰秒。

但是Java中很多获取时间戳的API并不是获取到Unix时间戳,而是获取到*从1970年1月1日(UTC/GMT的午夜)开始所经过的毫秒数***。以毫秒计算的时间戳下面统一称为时间戳

Java中获取时间戳的API

以获取当前时间的时间戳为例,下面将展示多种获取时间戳的办法:

  1. 说到常用的类,其实日期类java.util.Date也有对应的方法:

    //初始化Date对象Date date=new Date();//获取Date对象对应的时间戳System.out.println(date.getTime());
  2. 而除了最早的日期类java.util.Date其实后续新增的java.util.Calendar也提供相应的API:

    //初始化Calendar对象Calendar calendar=Calendar.getInstance();//获取Calendar对象对应的时间戳System.out.println(calendar.getTimeInMillis());
  3. 而说到了时间戳就不得不提java.sql.Timestamp这个时间戳对应的类:

    //初始化Timestamp,需要注意构造方法的入参是一个时间戳Timestamp timestamp=new Timestamp(System.currentTimeMillis());//获取Timestamp对象对应的时间戳System.out.println(timestamp.getTime());
  4. 难道Java中就不能直接获取Unix时间戳吗?当然不是,JDK8中新增的java.time.LocalDateTime就可以直接获取到Unix时间戳:

    //初始化时区对象,北京时间是UTC+8,所以入参为8ZoneOffset zoneOffset=ZoneOffset.ofHours(8);//初始化LocalDateTime对象LocalDateTime localDateTime=LocalDateTime.now();//获取LocalDateTime对象对应时区的Unix时间戳System.out.println(localDateTime.toEpochSecond(zoneOffset));

时间戳与Unix时间戳相互转换

时间戳与Unix时间戳相互转换其实很简单。因为时间戳是以毫秒为单位,而Unix时间戳是以秒为单位,所以可以得到一个公式:Unix时间戳=时间戳/1000,即时间戳=Unix时间戳*1000。那么转化的代码也很简单:

/**     * 时间戳转Unix时间戳     * @param timestamp     * @return     */    public long toUnixTimeStamp(long timestamp){        return timestamp/1000;    }    /**     * Unix时间戳转时间戳     * @param unixTimeStamp     * @return     */    public long toTimestamp(long unixTimeStamp){        return unixTimeStamp*1000;    }

转载地址:http://croub.baihongyu.com/

你可能感兴趣的文章
分布式系统理论基础4:Paxos
查看>>
分布式系统理论基础5:选举、多数派和租约
查看>>
分布式系统理论基础6:Raft、Zab
查看>>
分布式系统理论进阶7:Paxos变种和优化
查看>>
分布式系统理论基础8:zookeeper分布式协调服务
查看>>
搞懂分布式技术1:分布式系统的一些基本概念
查看>>
搞懂分布式技术2:分布式一致性协议与Paxos,Raft算法
查看>>
搞懂分布式技术3:初探分布式协调服务zookeeper
查看>>
搞懂分布式技术4:ZAB协议概述与选主流程详解
查看>>
搞懂分布式技术5:Zookeeper的配置与集群管理实战
查看>>
搞懂分布式技术6:Zookeeper典型应用场景及实践
查看>>
搞懂分布式技术10:LVS实现负载均衡的原理与实践
查看>>
搞懂分布式技术11:分布式session解决方案与一致性hash
查看>>
搞懂分布式技术12:分布式ID生成方案
查看>>
搞懂分布式技术13:缓存的那些事
查看>>
搞懂分布式技术14:Spring Boot使用注解集成Redis缓存
查看>>
搞懂分布式技术15:缓存更新的套路
查看>>
搞懂分布式技术16:浅谈分布式锁的几种方案
查看>>
搞懂分布式技术17:浅析分布式事务
查看>>
搞懂分布式技术18:分布式事务常用解决方案
查看>>