从文档:
(>>) : 依次组合两个动作,丢弃第一个动作产生的任何值
(*>):序列操作,丢弃第一个参数的值。
在我看来,两者都在做同样的工作。
在实践中,它们是等效的。
从历史上看,Haskell 没有Applicative
类型类(因此没有*>
),而只有一个Monad
类型类(带有>>
)。
在某一时刻,Applicative
被做成了Monad
. 那时,它被引入*>
为 的稍微更通用的变体>>
,它不需要与 monad 一起工作,而只需要与应用函子一起工作。
(*>) :: Applicative f => f a -> f b -> f b
(>>) :: Monad f => f a -> f b -> f b
最终结果是,当使用 applicatives 时,我们只能使用*>
,而在使用 monads(也是 applicatives)时,我们可以使用*>
或>>
互换使用,因为在这种情况下它们必须是等效的。
其他几个与 monad 相关的函数也被类似地推广到 applicatives:
return
概括为 pure
ap
概括为 <*>
mapM
概括为 traverse
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句