Closures

In our function definitions, we've referred to two different types of variables: the ones that are provided as parameters (bound variables) and others, which were defined in the enclosing block (free variables). The free variable is named so, because the function itself does not give any meaning to it.

A function that does not refer to any free variable is self-sufficient and the compiler can translate it to the bytecode in any context. Another way to state this is to say that this definition is closed in itself. It is named, accordingly, a closed term. A function referring to the free variables, on the other hand, can only be compiled in a context where all of these variables are defined. Therefore it is called open term and it closes over the free variables at the moment it is compiled, hence the name closure (over the free variables).

The usual scope resolution rules apply for closures in the same way that they apply for variables and other definitions as demonstrated by the next snippet:

scala> def outerA = {
| val free = 5
| def innerA = {
| val free = 20
| def closure(in: Int) = free + in
| closure(10)
| }
| innerA + free
| }
outerA: Int

scala> outerA
res3: Int = 35

The res3 is calculated as outerA.free (5) + innerA.free (20) + closure.in(10).

The free variable must be defined before the closure, otherwise, the compiler will complain:

scala> def noReference(in: Int) = {
| def closure(input: Int) = input + free + in
| }
def closure(input: Int) = input + free + in
^
On line 2: error: not found: value free

scala> def forwardReference(in: Int) = {
| def closure(input: Int) = input + free + in
| val free = 30
| }
def closure(input: Int) = input + free + in
^
On line 2: error: forward reference extends over definition of value free

The first try fails because we forgot to define a free variable. The second is still unsuccessful because the free variable is defined after the closure.

..................Content has been hidden....................

You can't read the all page of ebook, please click here login for view all page.
Reset
13.59.32.1