首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Scalaz(14)- Monad:函数组合-Kleisli to Reader

Monad Reader就是一种函数的组合。在scalaz里函数(function)本身就是Monad,自然也就是Functor和applicative。...在FP里这样的函数组合就是Monadic Reader。  但是FP里函数运算结果一般都是M[R]这样格式的,所以我们需要对f:A => M[B],g:B => M[C]这样的函数进行组合。...实际上Reader就是Kleisli的一个特殊案例:在这里kleisli的M[]变成了Id[],因为Id[A]=A >>> A=>Id[B] = A=>B,就是我们上面提到的Reader,我们看看Reader...输出Monad一致统一,都是Option。 那么,Kleisli到底用来干什么呢?它恰恰显示了FP函数组合的真正意义:把功能尽量细分化,通过各种方式的函数组合实现灵活的函数重复利用。...Option是个Monad,第一步可以通过。

74050

泛函编程(30)-泛函IO:Free MonadMonad生产线

我们知道,任何涉及IO的运算都会面临堆栈溢出问题。这是因为IO通常针对无法预计的数据量以及重复循环操作。所以IO算法设计也会采用与Trampoline一样的数据结构。...或者我们应该沿用Trampoline数据结构和算法来设计IO组件库。如此思考那么我们就必须对Trampoline进行深度抽象了。Free Monad就是Trampline的延伸。...包括IO操作,也就是说可以进行一些含有副作用(side effect)的操作。那么这个函数是无法实现函数组合(function composition)。...既然我们在本篇命题里提到Free MonadMonad生产线。那么用Free Monad能不能把Interact变成Monad呢?...如果我们用Free Monad来解决IO问题的话,堆栈溢出问题也是无法避免的。我们应该考虑在Free Monad里使用Trampoline类型。

1.1K70

15 分钟了解 Monad

看到函数式编程相关的资料的时候, 总是看到 Monad 这个词, 一直想了解一下, 然而查资料对 Monad 的定义往往是上来一大堆数学概念: Monad 是一个自函子范畴上的幺半群 鉴于本人数学基础实在太差...Monad 并不仅局限于函数式编程语言, 也可以用其他的语言来表示....标准的 Monad 库提供了几种预定义好的常用 monad(也就是 unit 和 bind 函数), 可以直接拿来用....在声明式的语言中, 他被用来实现命令式语言中的 日志和 IO 操作. 在命令式的语言中, 他可以用来减少和隔离冗余的胶水代码....本文只是简单地介绍 了 Monad 的一些只管解释, 还可以查看下面这些资料: Monad on Wikipedia Monads in Python List of Monad tutorials 本文主要翻译自

26410

当我们谈论Monad的时候(二)

IO操作中,这个优势还可以变得更加的明显。Haskell采用Monad实现IO相关的API,这个Monad就称为IO Monad。...通过Do表记可以写出很多符合直觉的代码,比如 main :: IO () main = do putStrLn "Hello" putStr "Plz enter your name: "...Haskell中的IO函数都会返回一个IO Monad,而上面的代码中,我们并没有对每一条都使用之前的结果。对于部分IO Monad(如putStrLn返回的),我们直接就抛弃了这些返回值。...而Monad的计算流程是可变的,这也意味着它的计算有“上下文”。一般的计算场景中都是有上下文的,比如IO运算。但是这种没有依赖的计算场景其实也是存在的,比如并发、Parser。...而且ZipList实际上是没有合法的Monad实现的。这里的合法不是说你实现Monad会报错,而是说你写的任意Monad都不符合Monad必须符合的定律。

77310
领券