Difference between revisions of "Closure (computer programming)"
From Wiki @ Karl Jones dot com
Karl Jones (Talk | contribs) (Free variables and bound variables) |
Karl Jones (Talk | contribs) (→See also) |
||
Line 15: | Line 15: | ||
* [[Free variables and bound variables]] | * [[Free variables and bound variables]] | ||
* [[Google Closure Tools]] | * [[Google Closure Tools]] | ||
+ | * [[Subroutine]] | ||
== External links == | == External links == |
Revision as of 04:17, 31 August 2015
In programming languages, a closure (also lexical closure or function closure) is a technique for implementing lexically scoped name binding in languages with first-class functions.
Description
Operationally, a closure is a data structure storing a function (see Subroutine) together with an environment:
- A mapping associating each free variable of the function (variables that are used locally, but defined in an enclosing scope)
- With the value or storage location the name was bound to at the time the closure was created.
A closure -- unlike a plain function -- allows the function to access those captured variables through the closure's reference to them, even when the function is invoked outside their scope.
See also
External links
The term closure has many different uses in different fields. See:
- Closure @ Wikipedia