开发手册 欢迎您!
软件开发者资料库

Haskell - Monads

Haskell Monads - 从简单和简单的步骤学习Haskell,从基本到高级概念,包括概述,环境设置,基本数据模型,基本操作符,决策,类型和类型类,函数,更多函数,函数组合,模块,输入和输出,Functor,Monads,拉链。

Monads 只不过是一种具有一些额外功能的Applicative Functor.它是一个Type类,它管理三个基本规则,称为 monadic rules .

所有这三个规则都严格适用于Monad声明,如下所示;

class Monad m where     return :: a -> m a    (>>=) :: m a -> (a -> m b) -> m b    (>>) :: m a -> m b -> m b    x >> y = x >>= \_ -> y    fail :: String -> m a     fail msg = error msg

适用于Monad声明的三个基本法则是 :

  • 左同身法 :   return 函数不会更改该值,也不应更改Monad中的任何内容.它可以表示为"return> => mf = mf".

  • 正确身份法 :   return 函数不会更改该值,也不应更改Monad中的任何内容.它可以表示为"mf> => return = mf".

  • Associativity : 根据这项法律,Functors和Monad实例应该以相同的方式工作.它可以在数学上表示为"(f> ==> g)> => h = f> =>(g> = h)".

前两个法则迭代相同的点,即 return 应该在 bind 运算符的两侧都有标识行为.

在我们之前的例子中,我们已经使用了很多Monads而没有意识到它们是Monad.请考虑以下示例,其中我们使用List Monad生成特定列表.

main = do   print([1..10] >>= (\x -> if odd x then [x*2] else []))

此代码将产生以下输出 :

  [2,6,10,14,18]