Difference between revisions of "Closure (computer programming)"

From Wiki @ Karl Jones dot com
Jump to: navigation, search
(etc)
(etc)
Line 1: Line 1:
In [[Programming language|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.
+
In [[Programming language|programming languages]], a '''closure''' (also '''lexical closure''' or '''function closure''') is a technique for implementing [[Scope (computer science)|lexically scoped]] [[name binding]] in languages with [[First-class function|first-class functions]].
  
 
Operationally, a closure is a data structure storing a function[a] together with an environment:  
 
Operationally, a closure is a data structure storing a function[a] together with an environment:  

Revision as of 07:43, 15 June 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.

Operationally, a closure is a data structure storing a function[a] 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: