函子, 适用函子和单子的Swift简单实现

Wadler的一句“Monad不就是自函子范畴上的幺半群吗?这有什么难理解的?”让多少不懂范畴论的FP萌新瑟瑟发抖,但用代码实现一下就立刻开窍。为什么说“Monad is just a semicolon”,为什么形容它为pipe,为什么说他是fp stateless的根基,都是在说一个贼简单的道理:单子就是“你要改变我的值,你告诉我你要干嘛,我帮你改,改完我告诉你”的无限循环。要我说,Monad就是像polymorphism一样起了一个欺生的名字。

Value & Context 值与封装

a -> Ca

class Context<T> {
    var value: T
    init(_ value: T) {
        self.value = value
    }
}

// 验证
let c = Context(1)
c.value // 1
复制代码

Functor 函子

(a -> b) -> Fa -> Fb

class Functor<T>: Context<T> {
    func map<U>(_ f: (T) -> U) -> Functor<U> {
        return Functor<U>(f(value))
    }
}

// 验证
let f = Functor(1)
let mapped = f.map { "\($0)" }
mapped.value // "1"
复制代码

Applicative Functor 适用函子

A(a -> b) -> Aa -> Ab

class Applicative<T>: Functor<T> {
    func apply<U>(_ f: Applicative<(T) -> U>) -> Applicative<U> {
        return Applicative<U>(f.value(value))
    }
}

// 验证
let a = Applicative(1)
let applied = a.apply(Applicative({ "\($0)" }))
applied.value // "1"
复制代码

Monad 单子

(a -> Mb) -> Ma -> Mb

class Monad<T>: Applicative<T> {
    func flatMap<U>(_ f: (T) -> Monad<U>) -> Monad<U> {
        return f(value)
    }
}

// 验证
let m = Monad(1)
let flatMapped = m.flatMap { Monad( "\($0)" ) }
flatMapped.value // "1"
复制代码
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值