首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用单例判别联合法生成计算表达式

用单例判别联合法生成计算表达式
EN

Stack Overflow用户
提问于 2017-04-21 07:13:57
回答 3查看 82关注 0票数 2

如果我有一个函数,试图将一个起始数除以两次。整个工作流必须返回一个布尔值。

代码语言:javascript
复制
let divideBy bottom top =
    if bottom = 0 then None
    else Some (top/bottom)

let divideByWorkflow init x y = 
    match init |> divideBy x with
    | None -> false
    | Some a -> 
        match a |> divideBy y with
        | None -> false
        | Some b -> true

let good = divideByWorkflow 12 3 2
let bad = divideByWorkflow 12 3 0

下面的生成器是正确的吗?

代码语言:javascript
复制
type BoolMaybe = BoolMaybe with
    member __.Bind (expr, f) =
        match expr with
        | Some value -> f value
        | None -> false
    member __.Return expr = expr

let divideByWorkflow init x y =
    BoolMaybe {
        let! a = init |> divideBy x
        let! b = a |> divideBy y
        return true
    }
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-04-21 09:27:00

我同意Dzoukr的回答,我的回答看起来有点不同:

代码语言:javascript
复制
let divideBy bot top =
    match bot with
    | 0 -> None
    | _ -> Some (top / bot)

let divideByWorkflow init x y =
    Some init
    |> Option.bind (divBy x)
    |> Option.bind (divBy y)
    |> Option.isSome

不需要计算表达式,在这里似乎没有增加任何好处。

票数 4
EN

Stack Overflow用户

发布于 2017-04-21 08:23:56

IMHO没有理由使用计算表达式使其变得更加复杂。我宁愿呆在几个简单的函数中,比如:

代码语言:javascript
复制
let divideBy bottom top =
    if bottom = 0 then None
    else Some (top/bottom)

let divideByTwoTimes init x y = 
    init |> divideBy x |> Option.bind (divideBy y)

let divideByWorkflow init x = divideByTwoTimes init x >> Option.isSome
票数 3
EN

Stack Overflow用户

发布于 2017-04-21 08:25:53

很有效,但我认为这是不必要的具体。如果您确实想使用CE,我宁愿定义一个普通的Maybe CE,然后执行

代码语言:javascript
复制
let divideByWorkflow init x y =
    Maybe {
        let! a = init |> divideBy x
        let! b = a |> divideBy y
        return true
    }
    |> Option.defaultValue false
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43536212

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档