Поскольку .plusSeconds
возвращает новое значение, а не изменяет исходное значение, вы получаете все результаты, плюс 600.
Вот пример LocalDateTime
или OffsetDateTime
scala> import java.time.LocalDateTime
import java.time.LocalDateTime
scala> val temp = LocalDateTime.now
temp: java.time.LocalDateTime = 2018-06-26T17:31:36.858
scala> Range (0, 10).map( _ => (temp.plusSeconds(600)))
res1: scala.collection.immutable.IndexedSeq[java.time.LocalDateTime] = Vector(
2018-06-26T17:41:36.858,
2018-06-26T17:41:36.858,
2018-06-26T17:41:36.858,
2018-06-26T17:41:36.858,
2018-06-26T17:41:36.858,
2018-06-26T17:41:36.858,
2018-06-26T17:41:36.858,
2018-06-26T17:41:36.858,
2018-06-26T17:41:36.858,
2018-06-26T17:41:36.858)
Если вы хотите инкрементное .plusSeconds
использование, может использовать шаблон аккумулятора,
scala> def add(start: Int, end: Int, date: LocalDateTime, dates: List[LocalDateTime]): List[LocalDateTime] = {
| if ( start == end ) dates
| else {
| val newDate = date.plusSeconds(600)
| add(start + 1, end, newDate, dates :+ newDate)
| }
| }
add: (start: Int, end: Int, date: java.time.LocalDateTime, dates: List[java.time.LocalDateTime])List[java.time.LocalDateTime]
scala> add(0, 10, LocalDateTime.now(), List.empty)
res19: List[java.time.LocalDateTime] = List(
2018-06-26T18:10:23.055,
2018-06-26T18:20:23.055,
2018-06-26T18:30:23.055,
2018-06-26T18:40:23.055,
2018-06-26T18:50:23.055,
2018-06-26T19:00:23.055,
2018-06-26T19:10:23.055,
2018-06-26T19:20:23.055,
2018-06-26T19:30:23.055,
2018-06-26T19:40:23.055)
Или вы можете использовать List.iterate
, который также в основном использует шаблон изменяемого аккумулятора.
def iterate[A](start: A, len: Int)(f: A => A): CC[A] = {
val b = newBuilder[A]
if (len > 0) {
b.sizeHint(len)
var acc = start
var i = 1
b += acc
while (i < len) {
acc = f(acc)
i += 1
b += acc
}
}
b.result()
}