PSA closures do not copy data

This is part of the Semicolon&Sons Code Diary - consisting of lessons learned on the job. You're in the architecture category.

Last Updated: 2025-01-18

I saw the following code and was surprised that when printX() was called the 2nd time, it displayed 10. I was under the false impression that a closure copied the "outer" variables at time of definition and kept a copy.

let x = 5
function printX() {
  console.log(x)
}

printX() // 5

x = 10
printX()  // 10

My assumption was incorrect. What a closure really does (here and across other languages, like Go) is act as if the function being defined (printX here) has an internal pointer to the stack frame containing all the local variables that were around when the function was defined (such as x). It doesn't copy the variables.

More officially, "The reason is that functions in JavaScript form closures. A closure is the combination of a function and the lexical environment within which that function was declared." (source: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Closures)

Resources