![](/img/trans.png)
[英]Scala transform Map[Int, Future[Seq[T]]] to Future[Map[Int, Seq[T]]]
[英]Scala - Map[Class[T], Seq[T]] - generics in key and values
我想创建一个包含对的 Map (类 - > 密钥 class 的对象的序列)。 下面的示例显然失败了,但它应该详细描述我需要什么。 我会很高兴你的帮助:)
object TestMain {
def main(args: Array[String]): Unit = {
val someMap: Map[Class[_], Seq[_]] = Map( //how to write this type correctly?
classOf[String] -> Seq("A", "B"),
classOf[Int] -> Seq(1, 2),
)
val typedValue: Seq[String] = someMap(classOf[String])//I want here type Seq[String] not Seq[_]
println(typedValue)
}
}
Map
本身无法做到这一点; 但是您可以创建一个包装器 class 。 就像是
class ClassSeqPair[T](val cls: Class[T], val value: Seq[T])
class ClassSeqPairs {
private var map = Map[Class[_], Seq[_]]
def put[T](cls: Class[T], value: Seq[T]) = {
map += (cls, value)
def apply[T](cls: Class[T]): Seq[T] = map(cls).asInstanceOf[Seq[T]]
}
object ClassSeqPairs {
def apply(pairs: ClassSeqPair[_]*): ClassSeqPairs = {
val result = new ClassSeqPairs
for (pair in pairs) {
result.put(pair.cls, pair.value)
}
result
}
}
利用:
object TestMain {
def main(args: Array[String]): Unit = {
val someMap: ClassSeqPairs = ClassSeqPairs(
ClassSeqPair(classOf[String], Seq("A", "B")),
ClassSeqPair(classOf[Int], Seq(1, 2)),
)
val typedValue: Seq[String] = someMap(classOf[String])
println(typedValue)
}
}
注意那里需要一些演员表。
适应口味(例如,使用ClassTag
避免手动传递类,如果需要,使其不可变等)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.