[Haskell-beginners] WWAAA... I hate monads
Jason Dusek
jason.dusek at gmail.com
Wed Apr 22 08:31:33 EDT 2009
2009/04/22 Daniel Carrera <daniel.carrera at theingots.org>:
> 1) Am I right in thinking that any type with two elements
> ("m a") is always a Monad? (IO String, Maybe Int, etc).
Well, no. Many such types are monads but not all of them.
Monads have the monadic operations `return` and `>>=`.
> 2) When I say "m a >>= f" the >>= just pulls the "a" out of "m
> a" and passes it to "f". Right?
Yes. The `>>=` operators defines our evaluation strategy; it
allows us to combine computations. Be carefult of confusing
`m` (a type constructor) with the value constructors for a
particular monad.
> 3) The last two properties are not comparing values but
> functions. Right? For example, reading the second-last
> property:
>
> (m >>= return) :: a -> m a
Not quite -- `someMonadicValue >>= return` is of type `m a`.
> Where (m >>= return) is defined by (\x -> m x >>= return).
> Right? And this is why you can write the last property:
>
> (k >>= h) :: a -> h a defined by (\x -> k a >>= h) This is
> what allows us to make (k >>= h) the second argument of ">>="
> as in the last property:
Actually, the third law is:
(m >>= f) >>= g = m >>= (\x -> f x >>= g)
--
Jason Dusek
More information about the Beginners
mailing list