更多精彩原文:
- 组件化开花,就问你香不香
- 架构师之路:重读设计模式《Head First 设计模式》
- kotlin如何解决java开发痛点,让程序员happier
- google为何选择kotlin?kotlin如何解决java开发痛点【续】?
- 深入浅出,kotin Any类
- 深入kotlin:const 对话 val,有必要用const申明变量吗?
- 一分钟入门kotiln协程,线程切换
- android获取进程名函数,如何优化到极致?
- android定位权限适配看这篇就够了
- 突破Android O 系统对Service的限制
- 详解:android O 对Service的限制【Background Execution Limits】
- 打破你的认知,java,除以0一定会崩溃吗?
- 把断言(Assert)用的淋漓精致,提高代码的健壮性
- java动态代理,轻轻松松从入门到精通
- 时间戳总结:System.nanoTime(),System.currentTimeMillis(),SystemClock
- 技巧1《不翻墙在线查看 android 开发文档 && 离线查看android 开发文档》
- 技巧2《adb root安卓模拟器,协助:问题跟进、android系统分析、竞品分析》
- 技巧3《android开发,通过main方法,写单元测试》
- 技巧4《android源码阅读及下载》
一、理解fold 和 reduce操作
直接看源码吧,别去搜别人写的blog了,这两个函数的源码比其他文档【包括官方文档】都更通俗易懂。而且可以秒懂。
完美诠释了:优秀的代码是最好的文档。
fold
public inline fun <T, R> Iterable<T>.fold(initial: R, operation: (acc: R, T) -> R): R {
var accumulator = initial
for (element in this) accumulator = operation(accumulator, element)
return accumulator
}
reduce
public inline fun <S, T : S> Iterable<T>.reduce(operation: (acc: S, T) -> S): S {
val iterator = this.iterator()
if (!iterator.hasNext()) throw UnsupportedOperationException("Empty collection can't be reduced.")
var accumulator: S = iterator.next()
while (iterator.hasNext()) {
accumulator = operation(accumulator, iterator.next())
}
return accumulator
}
二、fold与reduce有一个重要且容易忽略的区别:
reduce的返回值类型必须和集合的元素类型相符。
fold的返回值类型则不受约束。
三、实践:fold()和reduce()有什么用呢?
1. 如下我们通过reduce() 实现集合求和:
val numbers = listOf(1, 1, 1)
val result = numbers.reduce { a: Int, b: Int -> a + b }
println("reduceResult=$result")//result=3
2. 将集合拼接成字符串
val numbers = listOf(1, 1, 1)
val result = numbers.fold(StringBuilder()) {
str: StringBuilder, i: Int -> str.append(i).append(" ")
}
println("foldResult=$result")
来自大叔的灵魂拷问下大家:
如果numbers集合的元素为空时,result的结果是什么?
如果numbers集合的元素为空时,result的结果是什么?
如果numbers集合的元素为空时,result的结果是什么?
总结
fold : 合拢,折叠
reduce : 压缩
两个函数都是对集合的遍历,只是遍历完成之后能得到一个结果。
折叠和压缩的意思,大家可以理解为,将集合折叠成一个新的对象【对象的类型,可以与集合元素的类型无关】,或者压缩成一个值【类型必须和集合元素的类型一致】。
如果大叔的blog对你有一点点帮助、启发,请记得回来点个赞。原创不易。