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声明的三项基本法律是-

链接:https://www.learnfk.comhttps://www.learnfk.com/haskell/haskell-monads.html

来源:LearnFk无涯教程网

  • 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]

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

技术教程推荐

玩转Spring全家桶 -〔丁雪丰〕

零基础学Java -〔臧萌〕

小马哥讲Spring核心编程思想 -〔小马哥〕

说透敏捷 -〔宋宁〕

软件设计之美 -〔郑晔〕

Vim 实用技巧必知必会 -〔吴咏炜〕

动态规划面试宝典 -〔卢誉声〕

郭东白的架构课 -〔郭东白〕

超级访谈:对话玉伯 -〔玉伯〕

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