5

次のコードの最後の行が scala REPL でエラーをスローするのはなぜですか?

import scala.concurrent._
import scala.concurrent.duration._
import scala.concurrent.ExecutionContext.Implicits.global

// This is okay
val futureInt = Future[Int] { 42 }
val v1 = Await.result(futureInt, 1.second)

// This throw error: java.lang.NoClassDefFoundError: Could not initialize class $line8.$read$$iw$$iw$$iw$$iw$$iw$$iw$
val v2 = Await.result(Future[Int]{ 42 }, 1.second)

しかし、メイン クラスを作成して同じコードを実行すると、正常に動作します。

import scala.concurrent._
import scala.concurrent.duration._
import scala.concurrent.ExecutionContext.Implicits.global

object Main {
  def main(args: Array[String]): Unit = {
    val futureInt = Future[Int] { 42 }
    val v1 = Await.result(futureInt, 1.second)
    val v2 = Await.result(Future[Int] { 44 }, 1.second)
    println(s"v1=$v1, v2=$v2 ")
  }
}

出力:

v1=42、v2=44

4

1 に答える 1

1

このバグ (正確なソースを含む) は、scala に対するこのバグで追跡されています。

https://github.com/scala/bug/issues/9076#issuecomment-292435527

于 2018-12-26T15:21:15.763 に答える