У меня есть простая функция Scala, которая генерирует Json-файл с Map[String, Any]
.Удаление предупреждения «исключено путем стирания» в Scala
def mapToString(map:Map[String, Any]) : String = {
def interpret(value:Any) = {
value match {
case value if (value.isInstanceOf[String]) => "\"" + value.asInstanceOf[String] + "\""
case value if (value.isInstanceOf[Double]) => value.asInstanceOf[Double]
case value if (value.isInstanceOf[Int]) => value.asInstanceOf[Int]
case value if (value.isInstanceOf[Seq[Int]]) => value.asInstanceOf[Seq[Int]].toString.replace("List(", "[").replace(")","]")
case _ => throw new RuntimeException(s"Not supported type ${value}")
}
}
val string:StringBuilder = new StringBuilder("{\n")
map.toList.zipWithIndex foreach {
case ((key, value), index) => {
string.append(s""" "${key}": ${interpret(value)}""")
if (index != map.size - 1) string.append(",\n") else string.append("\n")
}
}
string.append("}\n")
string.toString
}
Этот код работает нормально, но в компиляции он выдает предупреждающее сообщение.
Warning:(202, 53) non-variable type argument Int in type Seq[Int] (the underlying of Seq[Int])
is unchecked since it is eliminated by erasure
case value if (value.isInstanceOf[Seq[Int]]) =>
value.asInstanceOf[Seq[Int]].toString.replace("List(", "[").replace(")","]")
^
Линия case value if (value.isInstanceOf[Seq[Int]])
вызывает предупреждение, и я попытался case value @unchecked if (value.isInstanceOf[Seq[Int]])
для удаленного предупреждения, но он не работает.
Как удалить предупреждение?
Пожалуйста, взгляните на 'mkString', похоже, что ваша функция может быть упрощена. 'map.toList.map {case (k, v) => s" "" "$ k": $ {interp (v)} "" "} .mkString (" {\ n ",", \ n ", "\ n} \ n") ' –
@ Łukasz: Это здорово. Благодаря! – prosseek