0

我很困惑为什么我不能从以下 Scala 代码行中产生一个集合:

val pairs = for( v <- vc; o <- oc) yield (v,o)

它在这个函数内部,它使用不可变向量。

 private def recMergeVirtualAndReal(mCell: RCell, vc: Vector[Cell], oc: Vector[Cell]): Vector[Cell] = {
        var temp_oc = oc
        val pairs = for( v <- vc; o <- oc) yield (v,o)
        val newVCells =
          for((left, right) <- pairs if left contains right) yield {
            temp_oc = temp_oc.filterNot(o => o == left || o == right)
            captureVCells(left,right,mCell)
          }
        if(newVCells.nonEmpty) recMergeVirtualAndReal(mCell, recMergeVirtualCells(newVCells ++ vc), temp_oc)
        else vc
      }

我在堆栈跟踪中收到以下错误:

Exception in thread "main" java.lang.ClassCastException: scala.collection.immutable.Vector cannot be cast to game.Cell
    at model.Board$$anonfun$10.apply(Board.scala:223)
    at scala.collection.immutable.List.flatMap(List.scala:327)

我很困惑,因为我不想强制转换任何东西,它只是一个没有任何类型转换的简单语句。

如果编译器无法理解类型,我也尝试了这个:

val pairs = for( v: Cell <- vc: Vector[Cell]; o: Cell <- oc: Vector[Cell]) yield (v: Cell,o: Cell)
4

1 回答 1

3

您可能在调用代码的某处进行了不安全的强制转换。检查函数的参数,并特别检查asInstanceOf.

这是一个不安全强制转换如何导致此问题的示例。首先,我们创建一个List[Int],然后强制编译器将其视为一个List[String].

val ls = List(1).asInstanceOf[List[String]]

这是可行的,因为 Scala 编译器可以使用它,并且在运行时未检查泛型,直到我们尝试将列表的元素存储到变量中:

val x = ls.head  // java.lang.ClassCastException: java.base/java.lang.Integer cannot be cast to java.base/java.lang.String

可能,在您的代码中的其他地方,您正在调用.asInstanceOf[Vector[Cell]]a Vector[Vector[Something]],然后将其传递给该函数。asInstanceOf如果你能帮助它,永远不要使用它。

于 2019-03-17T03:47:23.853 回答