镖。匿名函数的论证从哪里来?

时间:2018-07-06 01:13:14

标签: dart anonymous-function lexical-closures

在下面的示例中,有(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);
}

2 个答案:

答案 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.
}