我很困惑为什么我无法从以下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)
答案 0 :(得分: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]]
上调用Vector[Vector[Something]]
,然后将其传递给此函数。如果可以帮助,切勿使用asInstanceOf
。