Skip to content

Latest commit

 

History

History
93 lines (63 loc) · 3.15 KB

duration.md

File metadata and controls

93 lines (63 loc) · 3.15 KB

持续时间

持续时间(Duration)在整个 Akka 库中使用,因此这个概念由一个特殊的数据类型scala.concurrent.duration.Duration表示。此类型的值可以表示无限(Duration.InfDuration.MinusInf)或有限的持续时间,也可以表示未定义的持续时间(Duration.Undefined)。

依赖

为了使用Duration,你需要将以下依赖添加到你的项目中:

<!-- Maven -->
<dependency>
  <groupId>com.typesafe.akka</groupId>
  <artifactId>akka-actor_2.12</artifactId>
  <version>2.5.23</version>
</dependency>

<!-- Gradle -->
dependencies {
  compile group: 'com.typesafe.akka', name: 'akka-actor_2.12', version: '2.5.23'
}

<!-- sbt -->
libraryDependencies += "com.typesafe.akka" %% "akka-actor" % "2.5.23"

有限 vs. 无限

由于试图将无限的时间转换为具体的时间单位(如秒)会引发异常,因此在编译时可以使用不同的类型来区分这两种类型:

  • FiniteDuration保证是有限的,调用toNanos是安全的。
  • Duration可以是有限的,也可以是无限的,所以这种类型应该只在有限性不重要时使用;这是FiniteDuration的一种超类型。

Scala

在 Scala 中,可以使用mini-DSL构造持续时间,并支持所有预期的算术运算:

import scala.concurrent.duration._

val fivesec = 5.seconds
val threemillis = 3.millis
val diff = fivesec - threemillis
assert(diff < fivesec)
val fourmillis = threemillis * 4 / 3 // you cannot write it the other way around
val n = threemillis / (1 millisecond)
  • 注释:如果表达式被清晰地分隔(例如括号内或参数列表中),则可以省略点,但如果时间单位是一行中的最后一个标记,则建议使用点,否则,根据下一行的起始内容,分号推理可能会出错。

Java

Java 提供较少的语法糖,因此你必须将操作拼写为方法调用,而不是:

import scala.concurrent.duration.Duration;
import scala.concurrent.duration.Deadline;
final Duration fivesec = Duration.create(5, "seconds");
final Duration threemillis = Duration.create("3 millis");
final Duration diff = fivesec.minus(threemillis);
assert diff.lt(fivesec);
assert Duration.Zero().lt(Duration.Inf());

最后期限

Durations有一个兄弟名为Deadline,它是一个类,它持有绝对时间点的表示,并且支持通过计算现在和最后期限(deadline)之间的差异来派生一个持续时间。如果你想保持一个完整的最后期限,而不必注意簿记(book-keeping)工作,这是有用的。时间的流逝可以表示为:

val deadline = 10.seconds.fromNow
// do something
val rest = deadline.timeLeft

在 Java 中,利用持续时间创建这些:

final Deadline deadline = Duration.create(10, "seconds").fromNow();
final Duration rest = deadline.timeLeft();

英文原文链接Duration.


———— ☆☆☆ —— 返回 -> Akka 中文指南 <- 目录 —— ☆☆☆ ————