Haskell 中的 *> 和 >> 有什么区别?

雨果

从文档:

(>>) : 依次组合两个动作,丢弃第一个动作产生的任何值

(*>):序列操作,丢弃第一个参数的值。

在我看来,两者都在做同样的工作。

花费

在实践中,它们是等效的。

从历史上看,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] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章