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

泛型 – Scala的含义是否可以转换为更高级别的类型?

发布时间:2020-12-16 09:05:13 所属栏目:安全 来源:网络整理
导读:假设我有一个名为LongArrayWritable的类型,它是一个Longs数组的盒装表示.我有隐式定义,在这些类型之间转换: implicit def boxLongArray(array: Array[Long]) : LongArrayWritable { /*elided*/}implicit def unboxLongArray(array: LongArrayWritable) : Ar
假设我有一个名为LongArrayWritable的类型,它是一个Longs数组的盒装表示.我有隐式定义,在这些类型之间转换:

implicit def boxLongArray(array: Array[Long]) : LongArrayWritable { /*elided*/}
implicit def unboxLongArray(array: LongArrayWritable) : Array[Long] { /*elided*/}

现在,我也有一些暗示,它们以通用形式在java.lang.Iterable和scala.collection.List [X]之间进行转换:

implicit def iterator2list[X](it : java.lang.Iterable[X]) : List[X] { /* elided */ }
implicit def list2iterator[X](list : List[X]) : java.lang.Iterable[X] { /* elided */ }

使用这些定义,scala编译器可以推断java.lang.Iterable [LongArrayWritable]和List [Array [Long]]之间的隐式转换(相当于iterator2list(iterator).map(unboxLongArray(_))),或者这是超出implicits的能力,因此需要它自己的(显式?)隐式定义?

谢谢,

蒂姆

解决方法

有一篇帖子涵盖了这个问题: How can I chain implicits in Scala?.实质上,您需要有一个绑定转换为LongArrayWritable的视图.这意味着,转换为LongArrayWritable的隐式def接收一个隐式参数(称为视图绑定),因此该def的参数不是直接的Array,而是某些可以转换为Array的类型:

object LongArrayWritable {
  implicit def fromArraySource[A <% Array[Long]](a: A): LongArrayWritable = apply(a)
}
case class LongArrayWritable(a: Array[Long])

def test(a: LongArrayWritable): Unit = println("OK")

现在这适用于数组:

test(Array( 1L,2L,3L))

但是,由于Array不是Iterable,并且在范围内没有从Iterable到Array的默认转换,您需要添加一个:

implicit def iterable2Array[A: ClassManifest](i: Iterable[A]): Array[A] = i.toArray

然后它工作:

test(List(1L,3L))

视图边界A<%Array [Long]是类型A =>的隐式参数的快捷方式.数组[长],所以你也可以写

implicit def fromArraySource[A](a: A)(implicit view: A => Array[Long]) ...

(编辑:李大同)

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

    推荐文章
      热点阅读