[英]Custom computation expressions in F#
我一直在玩F#(也就是计算表达式)中的monads,我写了这个简单的Identity monad:
type Identity<'a> =
| Identity of 'a
type IdentityBuilder() =
member x.Bind (Identity v) f = f(v)
member x.Return v = Identity v
let identity = new IdentityBuilder()
let getInt() = identity { return Int32.Parse(Console.ReadLine()) }
let calcs() = identity {
let! a = getInt() // <- I get an error here
let! b = getInt()
return a + b }
我不明白我在标记的行中得到的错误:
该表达式应该具有Identity <'a>类型,但这里的类型为'b *'c
我认为这没有意义,因为getInt()显然是Identity<'a>
类型的值。
谁能告诉我我做错了什么?
问题是你的Bind
函数的类型 - 它不应该采用curried参数。 如果您将其更改为:
member x.Bind (Identity v, f) = f(v)
那它应该工作。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.