在下面的示例中,有(num i)
个东西,当makeAddr()
被调用时,它得到值?
Function makeAdder(num addBy) {
return (num i) => addBy + i;
}
void main() {
// Create a function that adds 2.
var add2 = makeAdder(2);
// Create a function that adds 4.
var add4 = makeAdder(4);
assert(add2(3) == 5);
assert(add4(3) == 7);
}
答案 0 :(得分:2)
这是一个关闭。当makeAdder返回时,它将返回一个在作用域中已经具有addBy的函数,并且该作用域被冻结。
答案 1 :(得分:2)
makeAdder
函数返回函数。它返回的函数是通过评估函数表达式(num i) => addBy + i
来创建的。
评估函数表达式时,将创建函数 value 。函数值也称为 closure ,因为它包含(“关闭”)函数体中的所有“自由”变量-函数表达式本身未声明的那些变量
在这种情况下,函数表达式(num i) => addBy + i
包含自由变量addBy
。函数值/闭包知道该变量的含义-这是对函数表达式进行评估的对makeAdder
的调用的参数。每次对makeAdder
的调用都会创建一个新的addBy
变量,并且每个调用还会创建一个新的闭包,并关闭该新变量。
闭包不只是存储变量的值,而是引用变量本身。您可以看到,如果您的闭包更改了变量的值。
示例:
/// Creates a counter function which returns a new value each call.
///
/// The counter function starts at [start] and increments by [step]
/// each time it is called.
int Function() makeCounter([int start = 1, int step = 1]) {
var value = start - step;
return () => value += step;
}
main() {
var countFrom1 = makeCounter();
var countFast = makeCounter(1, 2);
var countFrom100 = makeCounter(100);
// Prints 1, 2, 3, 4, 5:
for (var i = 0; i < 5; i++) print(countFrom1());
// Prints 1, 3, 5, 7, 9:
for (var i = 0; i < 5; i++) print(countFast());
// Prints 100, 101, 102, 103, 104:
for (var i = 0; i < 5; i++) print(countFrom100());
print(countFrom1()); // Prints 6.
}