[Haskell-cafe] Network.CGI -- practical web programming example.
wren ng thornton
wren at freegeek.org
Thu Jul 2 17:59:44 EDT 2009
Brandon S. Allbery KF8NH wrote:
> Some Haskell
> programmers use fmap (because most Monads are also Functors), others use
> liftM. Both have the same effect: given a monadic computation "m a",
> "liftM f" turns "f" into a function that operates on the enclosed "a"
> instead of the entire "m a".
That is, given the theory behind it all, every monad is a functor (note
the lower case); from which it follows that liftM == fmap. For
historical reasons the Monad typeclass does not require a Functor
instance, however, and so it's not the case that every Monad is also a
Functor (note the upper case).
The function liftM can be defined generically given definitions for
return and (>>=), so some prefer to use liftM to avoid the extra Functor
dependency. The function fmap can be given specialized definitions due
to overloading, so others prefer to use it for efficiency reasons. The
(<$>) function is just a symbolic name for fmap.
You'll also see the Applicative typeclass for "applicative functors".
Applicative does require a Functor instance, which is good. (And
actually, every monad is an applicative functor; though the Monad class
doesn't require Applicative either.) The function liftA can be defined
generically given definitions for pure and (<*>), and liftA == fmap as
well. The only reason anyone should use liftA is for defining a Functor
instance when they're too lazy to give a specialized implementation.
--
Live well,
~wren
More information about the Haskell-Cafe
mailing list