为什么 toString 在 String.valueOf() 投射时不起作用
Why toString does not work when String.valueOf() works at casting
我需要将 Json 解析为 Map[String,String] 结构。 Json 可能包含数字和字符串类型作为值。
因此,为了将它存储为字符串,我应用了 toString 方法,它抛出了 ClassCastException。但是,如果应用 String.valueOf() 一切正常。
- 为什么会这样?
- 如果有更好的方法来做这样的铸造?
import com.fasterxml.jackson.databind.ObjectMapper
import com.fasterxml.jackson.module.scala.DefaultScalaModule
import scala.collection.Map
import scala.util.parsing.json.JSON
val mapper = new ObjectMapper()
mapper.registerModule(DefaultScalaModule)
val str = "[ { \"name\": \"VehicleType\", \"value\": 11 }, { \"name\": \"VehicleWeight\", \"value\": \"12000\" } ]"
val customfields = JSON.parseFull(str) match {
case Some(map: List[Map[String, String]]) =>
// map.map(map => {map("name") -> map("value").toString}).toMap
// that throws:
// java.lang.ClassCastException: java.lang.Double cannot be cast to java.lang.String
// at #worksheet#.$anonfun$customfields.apply(scratch.scala2:14)
// at #worksheet#.$anonfun$customfields.apply(scratch.scala2:14)
// at scala.collection.immutable.List.map(scratch.scala2:269)
// at #worksheet#.customfields$lzycompute(scratch.scala2:14)
// that works fine
map.map(map => {map("name") -> String.valueOf(map("value"))}).toMap
case _ => Map.empty[String, String]
}
因为模式匹配匹配 List 类型,但不会一直匹配到映射中的所有类型,这就是为什么要输入 Some
子句。
所以,而不是
case Some(map: List[Map[String, String]]) =>
尝试这样做:
case Some(map: List[Map[String, _]]) =>
map.map(map => {map("name") ->
map("value") match {
case s: String => s
case i: java.lang.Number => i
case unexpectedType => throw Exception(s"Unexpected type $unexpectedType")
}.toString}).toMap
这就是您可以安全处理地图中每个值的方式。
我需要将 Json 解析为 Map[String,String] 结构。 Json 可能包含数字和字符串类型作为值。
因此,为了将它存储为字符串,我应用了 toString 方法,它抛出了 ClassCastException。但是,如果应用 String.valueOf() 一切正常。
- 为什么会这样?
- 如果有更好的方法来做这样的铸造?
import com.fasterxml.jackson.databind.ObjectMapper
import com.fasterxml.jackson.module.scala.DefaultScalaModule
import scala.collection.Map
import scala.util.parsing.json.JSON
val mapper = new ObjectMapper()
mapper.registerModule(DefaultScalaModule)
val str = "[ { \"name\": \"VehicleType\", \"value\": 11 }, { \"name\": \"VehicleWeight\", \"value\": \"12000\" } ]"
val customfields = JSON.parseFull(str) match {
case Some(map: List[Map[String, String]]) =>
// map.map(map => {map("name") -> map("value").toString}).toMap
// that throws:
// java.lang.ClassCastException: java.lang.Double cannot be cast to java.lang.String
// at #worksheet#.$anonfun$customfields.apply(scratch.scala2:14)
// at #worksheet#.$anonfun$customfields.apply(scratch.scala2:14)
// at scala.collection.immutable.List.map(scratch.scala2:269)
// at #worksheet#.customfields$lzycompute(scratch.scala2:14)
// that works fine
map.map(map => {map("name") -> String.valueOf(map("value"))}).toMap
case _ => Map.empty[String, String]
}
因为模式匹配匹配 List 类型,但不会一直匹配到映射中的所有类型,这就是为什么要输入 Some
子句。
所以,而不是
case Some(map: List[Map[String, String]]) =>
尝试这样做:
case Some(map: List[Map[String, _]]) =>
map.map(map => {map("name") ->
map("value") match {
case s: String => s
case i: java.lang.Number => i
case unexpectedType => throw Exception(s"Unexpected type $unexpectedType")
}.toString}).toMap
这就是您可以安全处理地图中每个值的方式。