加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Scala类型推迟

发布时间:2020-12-16 19:10:58 所属栏目:安全 来源:网络整理
导读:我正在使用Play framework 2.1和 Scala 2.10.1,并希望构建一个通用函数来从自定义案例类的List中构造一个JsArray. private def buildJsArray[T](l: List[T])(result: JsArray): JsArray = { l match { case List() = result case x::xs = buildJsArray(xs)(r
我正在使用Play framework 2.1和 Scala 2.10.1,并希望构建一个通用函数来从自定义案例类的List中构造一个JsArray.

private def buildJsArray[T](l: List[T])(result: JsArray): JsArray = {
    l match {
      case List() => result
      case x::xs => buildJsArray(xs)(result :+ Json.toJson(x)) // compiling error here!
    }
  }

用法:

val applyJsonArray = buildJsArray(List[Apple])(new JsArray())

但是,抛出了编译错误:

06002

我确实为特定的案例类(即Apple案例类)编写了一个Json反序列化器.

如何推迟编译器在运行时而不是在编译时检查x的类型?

非常感谢!

解决方法

如何修复错误

你必须像这样在你的方法中添加一个implicit parameter:

def buildJsArray[T](l: List[T])(result: JsArray)(implicit tjs: Writes[T]): JsArray

Json.toJson方法中有这样的参数.

您必须添加此参数的原因是您知道如何在知道T是什么时将T转换为json.这意味着只有在调用buildJsArray时才有序列化T的方法,并且此参数允许您将此序列化方法传递给方法buildJsArray.

如何构建JSArray

你可以使用JsArray的构造函数.它需要一个Seq [JsValue]:

new JsArray(l.map{Json.toJson(_)})

Traversable已经有一个implicit Writes,所以你不需要自己的方法buildJsArray,你可以使用方法Json.toJson和List [T]类型的参数.

加成

你应该看看集合api.它允许您编写更易读和更短的代码:

def buildJsArray[T](l: List[T])(implicit tjs: Writes[T]): JsArray =
  l.foldLeft(new JsArray){ (r,x) => r :+ Json.toJson(x) }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读