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

scala – 为什么列出一个Semigroup,但Seq不是?

发布时间:2020-12-16 09:44:30 所属栏目:安全 来源:网络整理
导读:我对于scalaz来说相当新鲜,我试图找出以下代码为什么工作: import scalaz._import Scalaz._scala Map[String,List[String]]() |+| Map[String,List[String]]()res3: scala.collection.immutable.Map[String,List[String]] = Map() 但这不… import scalaz.
我对于scalaz来说相当新鲜,我试图找出以下代码为什么工作:

import scalaz._
import Scalaz._
scala> Map[String,List[String]]() |+| Map[String,List[String]]()
res3: scala.collection.immutable.Map[String,List[String]] = Map()

但这不…

import scalaz._
import Scalaz._
scala> Map[String,Seq[String]]() |+| Map[String,Seq[String]]()
<console>:14: error: value |+| is not a member of      scala.collection.immutable.Map[String,Seq[String]]
          Map[String,Seq[String]]()

我看到Semigroup隐含的Map,但是我看不到List或Seq的地图。

几个问题:

> ListSemigroup隐含在哪里?
>为什么Seq不在那里?

解决方法

所以在Scalaz 7中有一个 implicit List to Monoid function给你一个Monoid [List [A]]。 Monoid扩展了SemiGroup,所以我们列举了覆盖。

Seq没有得到这种特殊待遇。没有从Seq到Monoid或Semigroup的隐式转换。有一个implicit IndexedSeq to Monoid,但这并没有帮助我们。

为什么Seq不是一个?我不知道。也许Seq违反了一些monoids / semigroups的规律,所以没有转换。在Scalaz 6中似乎有Seq的问题,所以他们已经删除了一些功能:
https://groups.google.com/forum/?fromgroups=#!searchin/scalaz/Seq/scalaz/Deaec1H11W4/gYFSquXjTzYJ

更新

看看scala文档,变得更加明显,为什么scalaz的人这样走。 List继承了继承Seq的LinearSeq。 IndexedSeq继承Seq。如果要为Seq提供半组,则可以覆盖IndexedSeq或LinearSeq上的任何其他半群,并且两者之间的性能优势将会松动。如果您查看附加的标尺签名,您可以看到他们利用这些性能差异:

https://github.com/scalaz/scalaz/blob/scalaz-seven/core/src/main/scala/scalaz/std/List.scala

implicit def listMonoid[A]: Monoid[List[A]] = new Monoid[List[A]] {
    def append(f1: List[A],f2: => List[A]) = f1 ::: f2
    def zero: List[A] = Nil
  }

https://github.com/scalaz/scalaz/blob/scalaz-seven/core/src/main/scala/scalaz/std/IndexedSeq.scala

implicit def ixSqMonoid[A]: Monoid[IxSq[A]] = new Monoid[IxSq[A]] {
    def append(f1: IxSq[A],f2: => IxSq[A]) = f1 ++ f2
    def zero: IxSq[A] = empty
  }

如果我们深入挖掘,我们看到Seq只实现了++,其列表上的性能比:::的附加操作性能更差。所以,回答你的第二个问题,表现。如果scalaz实现了Seq的半群,那么很可能会导致模糊的性能,因为您只能对索引进行优化。 Iterable有同样的问题。

(编辑:李大同)

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

    推荐文章
      热点阅读