“Functor, Applicative 和 Monad”的版本间的差异

来自wrc's Wiki
跳到导航 跳到搜索
 
第11行: 第11行:
  
 
;<code>(&gt;&gt;=)</code>: bind
 
;<code>(&gt;&gt;=)</code>: bind
 +
;<code>(&gt;&gt;)</code>: then 运算符。忽略上一个 Monad 的结果
 
;<code>(&gt;=&gt;)</code>: monad 复合,<code>(bs &gt;=&gt; cs) a</code> 可理解为 {{code|haskell|do { b <- bs a; cs b }<nowiki/>}}
 
;<code>(&gt;=&gt;)</code>: monad 复合,<code>(bs &gt;=&gt; cs) a</code> 可理解为 {{code|haskell|do { b <- bs a; cs b }<nowiki/>}}
 
;<code>(&lt;=&lt;)</code>: <code>flip (&gt;=&gt;)</code>,就像 <code>(.)</code> 运算符<ref>[[wikibooks:Haskell/Understanding_monads#Monadic_composition]]</ref>
 
;<code>(&lt;=&lt;)</code>: <code>flip (&gt;=&gt;)</code>,就像 <code>(.)</code> 运算符<ref>[[wikibooks:Haskell/Understanding_monads#Monadic_composition]]</ref>

2021年7月11日 (日) 04:46的最新版本

Functor

Functor 可被想象成 Mappable。

Applicative

Monad

相关函数

(>>=)
bind
(>>)
then 运算符。忽略上一个 Monad 的结果
(>=>)
monad 复合,(bs >=> cs) a 可理解为 do { b <- bs a; cs b }
(<=<)
flip (>=>),就像 (.) 运算符[1]

关系

MonadApplicative 的 superclass,ApplicativeFunctor 的 superclass。

相关函数的关系

对于一个 Monad

  • liftMfmap 可互换
  • ap(<*>) 可互换
  • returnpure 可互换

运用

需要给一个类型实现 Monad 时,应从 Functor 开始实现,再实现 ApplicativeMonad。如下

instance Functor Foo where
    fmap = -- etc.

instance Applicative Foo where
    pure = -- etc.
    (<*>) = -- etc.

instance Monad Foo where
    (>>=) = -- etc.

但由于 returnMonad 版本的 pureapMonad 版本的 (<*>),为了方便也可如下实现[2]

instance Monad Foo where
    return = -- etc.
    (>>=) = -- etc.

instance Applicative Foo where
    pure = return
    (<*>) = ap

instance Functor Foo where
    fmap = liftM

参考资料