fold<T> 方法

T fold<T>(
  1. T initialValue,
  2. T combine(
    1. T previousValue,
    2. E element
    )
)
override

通过迭代地将每个元素与一个现有的值组合来将集合收敛为一个单值

使用 initialValue 作为初始值,然后遍历元素,并使用 combine 函数根据每个元素更新值,就像这样:

var value = initialValue;
for (E element in this) {
  value = combine(value, element);
}
return value;

计算可迭代数的总和的例子

final numbers = <double>[10, 2, 5, 0.5];
const initialValue = 100.0;
final result = numbers.fold<double>(
    initialValue, (previousValue, element) => previousValue + element);
print(result); // 117.5

实现

T fold<T>(T initialValue, T combine(T previousValue, E element)) {
  var value = initialValue;
  int length = this.length;
  for (int i = 0; i < length; i++) {
    value = combine(value, this[i]);
    if (length != this.length) {
      throw ConcurrentModificationError(this);
    }
  }
  return value;
}