fold<T> 方法
- T initialValue,
- T combine(
- T previousValue,
- 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;
}