Swift函数式编程之Map&Reduce&Filter
- 什么是函数式编程呢?
- 函数式编程其实是一种编程思想, 代码写出来只是它的表现形式.
- 在面向对象的编程思想中, 我们将要解决的一个个问题, 抽象成一个个类, 通过给类定义属性和方法, 让类帮助我们解决需要处理的问题.(其实面向对象也叫命令式编程, 就像给对象下一个个命令)
- 而在函数式编程中, 我们则通过函数描述我们要解决的问题, 以及解决问题需要怎样的方案.
- 函数本身可以作为变量, 作为参数, 作为返回值(这样说有一点抽象, 下面的解决方案中就是将函数作为函数的参数)
一、Map和FlatMap和Zip的使用
1. Map的介绍
map用于将每个数组元素通过某个方法进行转换
- Map在此处并非地图的意思, 它的含义是映射
- 将一个元素映射成另外一种元素(类似于字典中的Key/Value映射)
- 其实Swift系统本身是有映射的函数, 可以将一个集合映射成另外一个集合
- map 方法接受一个闭包作为参数, 然后它会遍历整个数组,并对数组中每一个元素执行闭包中定义的操作。然后再返回一个操作后的数组;相当于对数组中的所有元素做了一个映射
示例分析:
实例一
let arr = [1,2,3,4,5,6]
let arr2 = arr.map({ $0 * 3})
//[3, 6, 9, 12, 15, 18]
let arr3 = arr.flatMap({ $0 + 2 })
//[3, 4, 5, 6, 7, 8]
2. flatMap
- 我们对同样的数组使用 flatMap 进行处理, 得到了同样的结果。 那 flatMap 和 map 到底有什么区别呢?
实例二
let numbersCompound = [[1,2,3],[4,5,6]];
var res = numbersCompound.map { $0.map{ $0 + 2 } }
// [[3, 4, 5], [6, 7, 8]]
var flatRes = numbersCompound.flatMap { $0.map{ $0 + 2 } }
// [3, 4, 5, 6, 7, 8]
- flatMap 依然会遍历数组的元素,并对这些元素执行闭包中定义的操作。 但唯一不同的是,它对最终的结果进行了所谓的 “降维” 操作。 本来原始数组是一个二维的, 但经过 flatMap 之后,它变成一维的了。
下面咱们再来看一下 flatMap 的定义, 还是抛去 @noescape, rethrows 这些无关逻辑的关键字:
func flatMap(transform: (Self.Generator.Element) throws -> T?) -> [T]
func flatMap(transform: (Self.Generator.Element) -> S) -> [S.Generator.Element]
- 和 map 不同, flatMap 有两