jjzjj

Java 8 LocalDateTime.now() 只提供毫秒精度

coder 2024-03-16 原文

是否可以在 Java 8 中获得微秒? Java 8 LocalDateTime类(class)有 .getNano()返回 nanoseconds 的方法,但在 Linux(Ubuntu) 和 OS X (10.11.5) 上它只返回 milliseconds (当我运行它时它返回 301000000 等于 301 milliseconds )我真的需要能够得到 microseconds .
我知道有可能获得 nanoseconds (因此从它获得 microseconds)在我的电脑上作为 javascript 方法 process.hrtime()返回一个精确的值。
在任何人开始精确与准确的争论之前,我知道纳秒在线程之间是完全不可靠的,不应该用于比较。
编辑 :
要清楚LocalDateTime类是 Java 8 java.time 的一部分类集。
更新 :
所以我意识到 Javascript 的 process.hrtime就像 Java 的 System.nanoTime()并且实际上与挂钟无关,是时候因为两种语言之间存在一些不同的任意值了。
新问题:有没有办法从这些值中解析时钟时间? IE。如果我得到 System.currentTimeMillis()System.nanoTime() ,并将其与另一组值进行比较,我可以获得第二组值的实际时间吗?
我的问题是我需要同时使用 Java 和 Javascript 进行日志记录,并且它们需要在两者之间具有一致的微秒字段。

最佳答案

tl;博士

Is it possible to get microseconds in Java 8?


否。使用 Java 9 或更高版本。
Instant.now()  // Returns a value in microseconds in Java 9 and later, but is restricted to mere milliseconds in Java 8.
这是指 Java 8/9 的 Oracle 和 OpenJDK 实现。其他人可能会有所不同。
Java 9 及更高版本
Java 9 有一个 fresh implementation java.time.Clock 能够以比毫秒(十进制小数的三位数字)更精细的分辨率捕获当前时刻。
实际分辨率取决于主机硬件时钟的限制。在带有 Oracle Java 9.0.4 的 macOS Sierra 上,我以微秒(十进制小数的六位数字)获得当前时刻。
Instant.now().toString()

2018-03-09T21:03:33.831515Z


java 8
java.time 类是 Java 8 中的新类。这些类被定义为携带纳秒(十进制小数的九位数字)。但是捕捉当前时刻在 Java 8 中仅限于 milliseconds ,并在 Java 9 中增强以捕捉更精细的当前时刻 microseconds

2018-03-09T21:03:33.831Z


其他事宜System.currentTimeMillis()

If I get System.currentTimeMillis() and System.nanoTime()


无需再次使用 System.currentTimeMillis()。而是在 UTC 中使用 java.time.Instant 片刻,分辨率精确到纳秒。
如果您真的需要从 1970-01-01T00:00Z 的纪元引用中计算毫秒数,请询问 Instant 对象。请注意数据丢失,因为您将忽略 Instant 中存在的任何微秒或纳秒。
long millisSinceEpoch = instant.now().toEpochMilli() ;

Is there a way that I can parse clock time from these values?


是的,您可以将自 1970-01-01T00:00Z 纪元以来的毫秒数转换为 Instant
Instant instant = Instant.ofEpochMilli( millisSinceEpoch ) ;
System.nanoTime()至于 System.nanoTime() ,它用于跟踪耗时,例如对代码的性能进行基准测试。调用 System.nanoTime() 不会告诉您有关当前日期时间的任何信息。
此值是自某些未记录的原始时间点以来的纳秒计数。在实践中,我已经看到这个数字似乎可以跟踪自 JVM 启动以来的时间,但是这种行为没有记录在案,因此您不应该依赖它。LocalDateTime 不是片刻

My problem is that I need to do logging using both Java and Javascript and they need to have a consistent microsecond field across both of them.


首先,对于日志记录,您不应该使用 LocalDateTime 类。该类故意缺少时区或UTC偏移量的任何概念。因此,LocalDateTime 不代表一个时刻,也不是时间线上的一个点。 LocalDateTime 是关于大约 26-27 小时范围内的潜在时刻的想法。仅当区域/偏移量未知(不是一个好情况)时才使用 LocalDateTime,或者如果这表示“圣诞节从 2018 年 12 月 25 日的第一个时刻开始”,其中圣诞节在全局不同地区的不同时刻开始,首先从远东(太平洋)开始,并在连续午夜后向西移动。
对于日志记录,您应该使用 UTC。在 Java 中,这将是 Instant 类,根据定义始终使用 UTC。只需调用 Instant.now()
序列化为文本(例如用于日志记录)时,请始终使用标准的 ISO 8601 格式。 java.time 类在解析/生成字符串时默认使用这些标准格式。你在这个答案中看到了上面的例子。
参见另一个问题 What's the difference between Instant and LocalDateTime?

ISO 8601
在 ISO 8601 中,秒的十进制小数可以有任意位数。所以你真的不应该关心记录的事件是以毫秒、微秒还是纳秒为单位记录的。
Instant instant = Instant.parse( "2018-03-09T21:03:33.123456789Z" ) ;
Instant instant = Instant.parse( "2018-03-09T21:03:33.123456Z" ) ;
Instant instant = Instant.parse( "2018-03-09T21:03:33.123Z" ) ;
截短
如果你真的相信你需要统一的分辨率,你可以 truncate a Instant
Instant instant = Instant.now().truncatedTo( ChronoUnit.MILLIS ) ; // Strip away any microseconds or nanoseconds.
不要担心分辨率

My problem is that I need to do logging using both Java and Javascript and they need to have a consistent microsecond field across both of them.


首先,我怀疑你真的需要关心这个。如果您使用标准 ISO 8601 格式和 Java 中的 Instant 类,您可以成功地以毫秒、微秒或纳秒为单位序列化和重新水合片刻。
即使小数秒分辨率发生变化,ISO 8601 格式的字符串也可以方便地按时间顺序按字母顺序排列。
其次,如果您出于某种原因试图将实际时刻跟踪到微秒,您可能会感到失望。截至 2018 年,传统的计算机时钟在微秒范围内并不可靠。

关于 java.time
java.time 框架内置于 Java 8 及更高版本中。这些类取代了麻烦的旧 legacy 日期时间类,例如 java.util.Date Calendar SimpleDateFormat
要了解更多信息,请参阅 Oracle Tutorial 。并在 Stack Overflow 上搜索许多示例和解释。规范是 JSR 310
Joda-Time 项目,现在在 maintenance mode 中,建议迁移到 java.time 类。
您可以直接与您的数据库交换 java.time 对象。使用符合 JDBC driver 或更高版本的 JDBC 4.2。不需要字符串,不需要 java.sql.* 类。 Hibernate 5 & JPA 2.2 支持 java.time。
从哪里获得 java.time 类?
  • Java SE 8Java SE 9Java SE 10Java SE 11 和更高版本 - 具有捆绑实现的标准 Java API 的一部分。
  • Java 9 带来了一些小功能和修复。

  • Java SE 6Java SE 7
  • 大多数 java.time 功能在 ThreeTen-Backport 中被反向移植到 Java 6 & 7。

  • Android
  • 更高版本的 Android (26+) 捆绑 java.time 类的实现。
  • 对于较早的 Android (<>API desugaring 的进程带来了 subset of the java.time 功能,该功能最初未内置于 Android 中。
  • 如果脱糖不能满足您的需求,ThreeTenABP 项目会将 ThreeTen-Backport(如上所述)适配到 Android。见 How to use ThreeTenABP…


  • 关于Java 8 LocalDateTime.now() 只提供毫秒精度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39586311/

    有关Java 8 LocalDateTime.now() 只提供毫秒精度的更多相关文章

    1. java - 等价于 Java 中的 Ruby Hash - 2

      我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

    2. java - 从 JRuby 调用 Java 类的问题 - 2

      我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

    3. java - 我的模型类或其他类中应该有逻辑吗 - 2

      我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我

    4. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

      什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

    5. Observability:从零开始创建 Java 微服务并监控它 (二) - 2

      这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/

    6. 【Java 面试合集】HashMap中为什么引入红黑树,而不是AVL树呢 - 2

      HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候

    7. 【Java入门】使用Java实现文件夹的遍历 - 2

      遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg

    8. [工业相机] 分辨率、精度和公差之间的关系 - 2

      📢博客主页:https://blog.csdn.net/weixin_43197380📢欢迎点赞👍收藏⭐留言📝如有错误敬请指正!📢本文由Loewen丶原创,首发于CSDN,转载注明出处🙉📢现在的付出,都会是一种沉淀,只为让你成为更好的人✨文章预览:一.分辨率(Resolution)1、工业相机的分辨率是如何定义的?2、工业相机的分辨率是如何选择的?二.精度(Accuracy)1、像素精度(PixelAccuracy)2、定位精度和重复定位精度(RepeatPrecision)三.公差(Tolerance)四.课后作业(Post-ClassExercises)视觉行业的初学者,甚至是做了1~2年

    9. java - 为什么 ruby​​ modulo 与 java/other lang 不同? - 2

      我基本上来自Java背景并且努力理解Ruby中的模运算。(5%3)(-5%3)(5%-3)(-5%-3)Java中的上述操作产生,2个-22个-2但在Ruby中,相同的表达式会产生21个-1-2.Ruby在逻辑上有多擅长这个?模块操作在Ruby中是如何实现的?如果将同一个操作定义为一个web服务,两个服务如何匹配逻辑。 最佳答案 在Java中,模运算的结果与被除数的符号相同。在Ruby中,它与除数的符号相同。remainder()在Ruby中与被除数的符号相同。您可能还想引用modulooperation.

    10. java - Ruby 相当于 Java 的 Collections.unmodifiableList 和 Collections.unmodifiableMap - 2

      Java的Collections.unmodifiableList和Collections.unmodifiableMap在Ruby标准API中是否有等价物? 最佳答案 使用freeze应用程序接口(interface):Preventsfurthermodificationstoobj.ARuntimeErrorwillberaisedifmodificationisattempted.Thereisnowaytounfreezeafrozenobject.SeealsoObject#frozen?.Thismethodretur

    随机推荐