Skip to main content Link Menu Expand (external link) Document Search Copy Copied

Functional Programming

In computer science, functional programming is a programming paradigm where programs are constructed by applying and composing functions. It is a [declarative-programming] paradigm in which function definitions are trees of expressions that each return a value, rather than a sequence of imperative statements which change the state of the program.

In functional programming, functions are treated as first-class citizens, meaning that they can be bound to names (including local identifiers), passed as arguments, and returned from other functions, just as any other data type can. This allows programs to be written in a declarative and composable style, where small functions are combined in a modular manner.

Examples