Próbowałem zaimplementować tę prostą monadę Maybe
. Zasadniczo całe wyrażenie ma wartość Nothing
, jeśli jednym ze środkowych kroków jest Nothing
.Wyrażenie obliczeń F #, gdy jest to połączenie o nazwie
type Maybe<'a> =
| Just of 'a
| Nothing
type MaybeBuilder() =
member this.Combine ((first, second) : Maybe<'a> * Maybe<'b>) : Maybe<'b> =
printfn "Combine called"
match first with
| Nothing -> Nothing
| _ ->
match second with
| Nothing -> Nothing
| _ as a -> a
member this.Zero() = Just()
member this.Bind((m, f) : Maybe<'a> * ('a -> Maybe<'b>)) =
printfn "Bind called"
match m with
| Nothing -> Nothing
| Just a -> f a
let MaybeMonad = MaybeBuilder()
let foobar =
MaybeMonad {
let! foo = Just "foo"
Just 1
Nothing
}
Spodziewałem foobar
być przetłumaczone na język Just "foo" >>= fun foo -> Combine(Just 1, Nothing)
jednak Combine
nie został powołany.
Następnie przejdź do tego artykułu z bardzo ładną serią artykułów: https://fsharpforfunandprofit.com/series/computation-expressions.html – rmunn