OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE.md file. |
| 4 |
| 5 const numbers = const <int>[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; |
| 6 |
| 7 main() { |
| 8 var closures = []; |
| 9 for (int i in numbers) { |
| 10 int j = i; |
| 11 closures.add(() => j); |
| 12 } |
| 13 int sum = 0; |
| 14 for (Function f in closures) { |
| 15 sum += f(); |
| 16 } |
| 17 // This formula is credited to Gauss. Search for "Gauss adding 1 to 100". |
| 18 int expectedSum = (numbers.length - 1) * numbers.length ~/ 2; |
| 19 if (expectedSum != sum) { |
| 20 throw new Exception("Unexpected sum = $sum != $expectedSum"); |
| 21 } |
| 22 } |
OLD | NEW |