Duration
在整个Akka库里面都在使用Duration,因此这个概念由特殊的数据类型scala.concurrent.duration.Duration表示。这个数据类型的值代表一个有限的或者无限(Duration.Inf, Duration.MinusInf)的持续时间,或者是Duration.Undefined.
有限 vs. 无限
由于尝试将有限的持续时间转换为一个具体时间单位,比如秒,会抛出异常,所以在编译时由不同的类型区分这两种类型:
· FiniteDuration保证是有限的,调用toNanos和friends方法是安全的
· Duration可以是有限的或者无限的,所以这种类型应该只在有限性没有那么重要时使用;这是FiniteDuration的超类
Scala
在Scala中的,可用mini-DSL构造Duration,并支持所有预期的算术操作:
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
截止期限
Duration有一个兄弟名为Deadline,Deadline类持有一个绝对时间点的表示,支持通过计算现在和截止期限之间的差异导出duration。当你想要保持整体的截止日期而不需要关心簿记,这将是很有用的。自己传入时间:
val deadline = 10.seconds.fromNow
// do something
val rest = deadline.timeLeft
在Java中,你可以通过Duration创建Deadline:
final Deadline deadline = Duration.create(10,"seconds").fromNow();
final Duration rest = deadline.timeLeft();