Functor, Applicative 和 Monad

Weirane讨论 | 贡献2021年7月11日 (日) 03:23的版本

关系

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 版本的 (<*>),为了方便也可如下实现[1]

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

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

instance Functor Foo where
    fmap = liftM

参考资料