scala – 如何使用隐式转换将List [A]转换为List [B]
发布时间:2020-12-16 09:03:51 所属栏目:安全 来源:网络整理
导读:我有以下用例经常出现在我的代码中: 收藏品[A] 隐式转换A到B. 我想获得一个B的集合.我可以隐式使用如下: case class Items(underlying:List[B]) import B._ def apply(a:List[A]):Items = { val listOfB= a.map {implicitly[A=B]} Items(listOfB) } 在Scal
我有以下用例经常出现在我的代码中:
>收藏品[A] 我想获得一个B的集合.我可以隐式使用如下: case class Items(underlying:List[B]) import B._ def apply(a:List[A]):Items = { val listOfB= a.map {implicitly[A=>B]} Items(listOfB) } 在Scala中最优雅的方法是什么,也许在Scalaz的帮助下做同样的事情? 编辑:我的问题的目标是找到一种惯用的方式,这是图书馆/开发者之间的共同方法.在这种意义上,开发我自己的pimp-my-library解决方案是我不喜欢的,因为编写我的代码的其他人不会知道这种转换的存在并且不会使用它,并且他们将重写他们自己的.我赞成使用库方法来实现这个常见功能,这就是为什么我想知道在Scalaz中是否存在这样的功能. 解决方法
如果你知道类型,那就非常简单了.首先从A到B的隐式转换:
implicit def conversion(a: A): B = //... 那么你需要从List [S]到List [T]的隐式转换,其中S和T是从S到T的隐式转换存在的任意类型: implicit def convList[S,T](input: List[S])(implicit c: S => T): List[T] = input map c 这应该工作: val listOfA: List[A] = //... val listOfB: List[B] = listOfA 这由编译器解决: val listOfB: List[B] = convList(listOfA)(conversion) 其中S是A,T是B. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |