繁体   English   中英

Scala - Map[Class[T], Seq[T]] - generics 在键和值中

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM