Monads 只是一种带有某些附加函数的Applicative Functor,它是一个Type类,它管理称为 monadic规则的三个基本规则。
所有这三个规则严格适用于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声明的三项基本法律是-
Left Identity Law - 返回函数不会更改值,并且在Monad中也不应更改任何内容。 可以表示为"return> => mf=mf"。
Right Identity Law - 返回函数不会更改值,并且在Monad中也不应更改任何内容。 可以表示为"mf> => return=mf"。
Associativity - Functor和Monad实例应以相同方式工作, 它可以用数学表示为“(f> ==> g)> => h=f> =>(g>=h)"。
在前面的示例中,我们已经使用了许多Monad,而没有意识到它们是Monad。考虑下面的示例,其中我们使用List Monad生成特定列表。
main=do print([1..10] >>= (\x -> if odd x then [x*2] else []))
此代码将产生以下输出-
[2,6,10,14,18]