Skip to Content
Learning Functional Programming in Go
book

Learning Functional Programming in Go

by Lex Sheehan
November 2017
Intermediate to advanced
670 pages
17h 35m
English
Packt Publishing
Content preview from Learning Functional Programming in Go

Monadic functions

Monads are implemented as a type class with two methods, return and bind (>>=):

class Monad m where return :: a -> m a  (>>=) :: m a -> (a -> m b) -> m b

Note that m refers to a type constructor, such as Either or Maybe, that implements the Monad type class.

We'll include a few more monadic functions from the Standard Library in the following table:

Function

Description

fail

The fail function supports a monad's implementation of failure. We get the fail function from the Monad type class, and it enables a failed pattern matching to result in a failure in the context of the current monad instead of a program crash. For example, the fail function is called when pattern matching fails in a do expression. 

fail :: ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Start your free trial

You might also like

Learning Functional Programming

Learning Functional Programming

Jack Widman

Publisher Resources

ISBN: 9781787281394Supplemental Content