JSON.toJSONString 报错:ambiguous reference to overloaded definition
原因分析:Java在编译时,首先会根据实参的数量和类型(这里是2个实参,都为int类型,注意没有转成int数组)来进行处理,编译器想要“偷懒”,于是它会从最简单的开始“猜想”,只要符合编译条件的即可通过。
Scala分辨重载方法的过程与Java极为相似。任何情况下,被选中的重载版本都是最符合参数静态类型的那个。有时如果不止一个最符合的版本;这种情况下编译器会给你一个“ambiguous reference to overloaded definition”(模糊引用了重载定义的方法)的错误。
如果是原生的scala方法,则不会报这种错误。
如下两个方法在scala中使用
static String toJSONString(Object object) {
...
}
static String toJSONString(Object object, com.alibaba.fastjson2.JSONWriter.Feature... features) {
...
}
//在scala中使用会报错
JSON.toJSONString(str)//报错
//原生scala,不报错
object FUN4{
def func(a:Int,str:String*): Unit ={
println(a)
}
def func(a:Int): Unit ={
println(a)
}
}
FUN4.func(12)//不报错
解决方法1:
参考:https://stackoverflow.com/questions/6209120/scala-ambiguous-reference-to-overloaded-definition-with-varargs
解决方法2:
import scala.collection.mutable
import com.alibaba.fastjson2.JSON
import com.alibaba.fastjson2.JSONWriter
import com.alibaba.fastjson2.JSONReader
//import com.alibaba.fastjson.JSON
//import com.alibaba.fastjson.serializer.SerializerFeature
JSON.toJSONString(jsonStr,JSONWriter.Feature.PrettyFormat)//fastjson2:
JSON.toJSONString(jsonStr,SerializerFeature.PrettyFormat)//fastjson:
//或
JSON.toJSONString(jsonStr,Array[JSONWriter.Feature](): _*))//fastjson2
输出{“empty”:false,“traversableAgain”:true}的问题:
因为直接用scala类,做toJSONString的转化会出问题,要先用asJava转成java类型:
val m2=Map("a"->"1","b"->"2")
println(JSON.toJSONString(m2.asJava, Array[JSONWriter.Feature](): _*))
//输出{"empty":false,"traversableAgain":true}
import collection.JavaConverters._
//转为java类即可
println(JSON.toJSONString(m2.asJava, Array[JSONWriter.Feature](): _*))
//输出 {"a":"1","b":"2"}