我检查了下面的页面,在 2009 年的 Java 中没有方法可以精确地以微秒为单位获取当前时间。
Current time in microseconds in java
最好的是 System.currentTimeMillis() ,它给出当前时间,精度为毫秒,而 System.nanoTime() 给出当前时间戳,精度为纳秒,但是这个时间戳不能用来转换为当前时间,精度很高准确性。
我想知道 Java 6 年后是否有任何新的更新?谢谢。
编辑 1. System.nanoTime() 对于估计持续时间很有用,但不能给出当前时间。
编辑 2. 在 Java 8 中有解决方案很好。在 Java 7 中还有其他方法吗?谢谢!
最佳答案
Instant.now()
2018-03-09T21:03:33.831515Z
使用 Java 9之后,您可能可以使用 microseconds 捕捉当前时刻分辨率。
上面看到的例子是 Oracle Java 9.0.4 for macOS Sierra .注意小数秒的 6 位,表示微秒。
内置于 Java 8 及更高版本中的 java.time 框架具有表示分辨率为 nanoseconds 的日期时间值的类。 , 秒的小数点后 9 位。
Java 9 有一个 fresh implementation Clock 分辨率高达纳秒级。实际值取决于任何特定计算机的底层硬件时钟的限制。
有关更多信息,请参阅问题,Why does the new Java 8 Date Time API not have nanosecond precision? .
避免使用较旧的日期时间类。 java.util.Date/.Calendar 等与早期版本的 Java 捆绑在一起的类只有毫秒分辨率。同样适用于 Joda-Time .两者都被 java.time 类取代。
Java 8 实现了 Clock仅与 millisecond 接口(interface)分辨率(小数秒的 3 位数字)。因此,虽然 java.time 类能够携带纳秒,但它无法捕获纳秒的当前时间。
也许您可以编写或找到 Clock 的实现调用主机操作系统中的 native 库以获得更准确的时间。
如果您碰巧已经在使用数据库,您可以询问它的时间。从 JDBC 4.2 及更高版本开始,您可以直接与数据库交换 java.time 对象。
Instant instant = myPreparedStatement.getObject( … , Instant.class ) ;
在 JDBC 4.2 之前,您可能会遇到麻烦的遗留 java.sql.Timestamp,它具有纳秒分辨率。例如,Postgres提供 microsecond分辨率(假设主机时钟支持),小数秒的 6 位数字。您可以使用添加到旧类的新方法将 java.sql.Timestamp 转换为 Instant 和 ZonedDateTime。
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 类?
ThreeTen-Extra项目用附加类扩展 java.time。该项目是 future 可能添加到 java.time 的试验场。您可能会在这里找到一些有用的类,例如 Interval , YearWeek , YearQuarter , 和 more .
关于java - 现在有什么新方法可以在 Java 中以微秒为单位准确获取当前时间?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33472569/
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
查看Ruby的CSV库的文档,我非常确定这是可能且简单的。我只需要使用Ruby删除CSV文件的前三列,但我没有成功运行它。 最佳答案 csv_table=CSV.read(file_path_in,:headers=>true)csv_table.delete("header_name")csv_table.to_csv#=>ThenewCSVinstringformat检查CSV::Table文档:http://ruby-doc.org/stdlib-1.9.2/libdoc/csv/rdoc/CSV/Table.html
它不等于主线程的binding,这个toplevel作用域是什么?此作用域与主线程中的binding有何不同?>ruby-e'putsTOPLEVEL_BINDING===binding'false 最佳答案 事实是,TOPLEVEL_BINDING始终引用Binding的预定义全局实例,而Kernel#binding创建的新实例>Binding每次封装当前执行上下文。在顶层,它们都包含相同的绑定(bind),但它们不是同一个对象,您无法使用==或===测试它们的绑定(bind)相等性。putsTOPLEVEL_BINDINGput
我发现ActiveRecord::Base.transaction在复杂方法中非常有效。我想知道是否可以在如下事务中从AWSS3上传/删除文件:S3Object.transactiondo#writeintofiles#raiseanexceptionend引发异常后,每个操作都应在S3上回滚。S3Object这可能吗?? 最佳答案 虽然S3API具有批量删除功能,但它不支持事务,因为每个删除操作都可以独立于其他操作成功/失败。该API不提供任何批量上传功能(通过PUT或POST),因此每个上传操作都是通过一个独立的API调用完成的
我可以得到Infinity和NaNn=9.0/0#=>Infinityn.class#=>Floatm=0/0.0#=>NaNm.class#=>Float但是当我想直接访问Infinity或NaN时:Infinity#=>uninitializedconstantInfinity(NameError)NaN#=>uninitializedconstantNaN(NameError)什么是Infinity和NaN?它们是对象、关键字还是其他东西? 最佳答案 您看到打印为Infinity和NaN的只是Float类的两个特殊实例的字符串