FastJSON JSON.toJSONString 报错:ambiguous reference to overloaded definition

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"}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`JSON.toJSONString()` 是 Java 中用于将对象转换为 JSON 字符串的方法。它属于 `com.alibaba.fastjson.JSON` 类中的一个静态方法。 以下是 `JSON.toJSONString()` 方法的功能和用法: 1. 将 Java 对象转换为 JSON 字符串:`JSON.toJSONString(Object object)` - 该方法将给定的 Java 对象转换为对应的 JSON 字符串表示形式。 - 例如:`String jsonString = JSON.toJSONString(student);` 2. 设置序列化选项:`JSON.toJSONString(Object object, SerializerFeature... features)` - 该方法可以通过传递一个或多个 `SerializerFeature` 枚举值作为参数,来设置序列化选项。 - 例如:`String jsonString = JSON.toJSONString(student, SerializerFeature.WriteDateUseDateFormat);` 3. 序列化集合类型:`JSON.toJSONString(Collection<?> collection)` - 该方法可以将 Java 集合类型(如 List、Set)转换为对应的 JSON 字符串表示形式。 - 例如:`String jsonString = JSON.toJSONString(studentList);` 4. 序列化数组类型:`JSON.toJSONString(Object[] array)` - 该方法可以将 Java 数组类型转换为对应的 JSON 字符串表示形式。 - 例如:`String jsonString = JSON.toJSONString(studentArray);` 5. 序列化 Map 类型:`JSON.toJSONString(Map<?, ?> map)` - 该方法可以将 Java Map 类型转换为对应的 JSON 字符串表示形式。 - 例如:`String jsonString = JSON.toJSONString(studentMap);` 需要注意的是,在使用 `JSON.toJSONString()` 方法之前,需要在项目中引入 FastJson 库的依赖。 希望这能帮到你!如果你还有其他问题,请随时问我。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值