从Map

时间:2015-08-03 08:21:20

标签: scala type-erasure typed

我想将一些数据放入HashMap,并使用函数将其作为类型化值检索。该函数采用期望的类型,并且在值未存储在HashMap中时也采用默认值。 JVM的类型擦除使这变得棘手。

问:如何检索输入的值?

以下代码和结果。

abstract class Parameters(val name: String) {
  val parameters = new HashMap[String, Any]()

  def put(key: String, value: Any) = parameters(key) = value

  def get(key: String) = parameters.getOrElse(key, None)

  def remove(key: String) = parameters.remove(key)


  def g0[T: TypeTag](key: String, defaultValue: T) = {
    get(key) match {
      case x: T => x
      case None => defaultValue
      case _ => defaultValue
    }
  }


  def g1[T: ClassTag](key: String, defaultValue: T) = {
    val compareClass = implicitly[ClassTag[T]].runtimeClass

    get(key) match {
      case None => defaultValue
      case x if compareClass.isInstance(x) => x.asInstanceOf[T]
    }
  }
}

class P extends Parameters("AParmList") {
  put("1", 1)
  put("3", "three")
  put("4", 4.0)
  put("width", 600)

  println(g0[Int]("width", -1))
  println(g0[Int]("fail", -2))
  println(g1[Int]("width", -3))
  println(g1[Int]("fail", -4))
}


object TypeMatching {
  def main(args: Array[String]) {
    new P
  }
}

输出是(括号中的注释): 600(如预期) 无(预期-2) 和匹配错误(存储java.lang.Integer,需要Int)

0 个答案:

没有答案