Haskell - Monads

Haskell - Monads 首页 / Haskell入门教程 / Haskell - Monads

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]

祝学习愉快!(内容编辑有误?请选中要编辑内容 -> 右键 -> 修改 -> 提交!)

技术教程推荐

微服务架构核心20讲 -〔杨波〕

Spring Boot与Kubernetes云原生微服务实践 -〔杨波〕

分布式技术原理与算法解析 -〔聂鹏程〕

Netty源码剖析与实战 -〔傅健〕

检索技术核心20讲 -〔陈东〕

Redis核心技术与实战 -〔蒋德钧〕

代码之丑 -〔郑晔〕

讲好故事 -〔涵柏〕

程序员的个人财富课 -〔王喆〕

好记忆不如烂笔头。留下您的足迹吧 :)