- Non-local variable
-
In programming language theory, a non-local variable is a variable that is not defined in the local scope. While the term can refer to global variables, it is primarily used in the context of nested and anonymous functions where some variables can be neither in the local nor the global scope.
Example
In the example that follows there is a nested function
inner
defined in the scope of another functionouter
. The variablex
is local toouter
, but non-local toinner
(nor is it global):def outer(): x = 1 def inner(): nonlocal x x += 1 print(x) return inner
In the next example the variable
c
is non-local in the anonymous function\x -> x + c
:outer = let c = 1 in map (\x -> x + c) [1, 2, 3, 4, 5]
Implementation issues
Non-local variables are the primary reason it is difficult to support nested, anonymous, higher-order and thereby first-class functions in a programming language.
If the nested function or functions are (mutually) recursive, it becomes hard for the compiler to know exactly where on the stack the non-local variable was allocated, as the frame pointer only points to the local variable of the nested function itself and there can be an arbitrary number of activation records on the stack in between. This is generally solved using access links or display registers.
If the nested function is passed as an argument to a higher-order function a closure needs to be built in order to locate the non-local variables. If the nested function is returned as a result from its outer function (or stored in a variable) the non-local variables will no longer be available on the stack. They need to be heap allocated instead, and their lifetime extend beyond the lifetime of the outer function that declared and allocated them. This generally requires garbage-collection.
References
- Aho, Lam, Sethi, and Ullman. "7.3 Access to Nonlocal Data on the Stack". Compilers: Principles, Techniques, & Tools. Second edition.
Categories:- Computer science stubs
- Programming language theory
- Variable (computer programming)
Wikimedia Foundation. 2010.