swift 数组高阶使用(二)
这次主要讲解swift中map、flatmap、filter、reduce对数组的操作,你会发现,你的数组变得非常简单,上代码:
- map
被一个数组调用,并且可以接受一个闭包,返回原数组各元素经过闭包处理以后所得到的元素组成的数组
// 原来的数组
let textArr = ["魔兽", "惊天魔盗团2", "X战警:天启"]
// 一个闭包
func addHD(movieName:String) ->String {
let newName = movieName + "_HD"
return newName
}
// 新数组
let newArr = textArr.map(addHD)
print(newArr)//["魔兽_HD", "惊天魔盗团2_HD", "X战警:天启_HD"]
// 或者可以直接写为:
let newArr2 = textArr.map {(movieName:String)->String? in
let newName = movieName + "_HD"
return newName
}
// 当然,还有最简单的方法
let newArr3 = textArr.map{("\($0)_HD")}
- flatmap
flatmap和map的功能一样,但是flatmap会自动剔除返回元素中为nil的元素,并且返回的不再是可选值,而是强制解析以后的非可选值。所以在flatmap和map的使用中我们需要做一个选择。
- filter
顾名思义,filter就是过滤的意思,可以将数组中的所有元素遍历进行过滤
let num = [1, 2, 3, 4, 5, 6, 7, 8]
let result = num.filter{$0 < 5}
print(result) // [1, 2, 3, 4]
- reduce
Reduce 是 map、flatMap 或 filter 的一种扩展的形式(译者注:后三个函数能干嘛,reduce 就能用另外一种方式实现)Reduce 的基础思想是将一个序列转换为一个不同类型的数据,期间通过一个累加器(Accumulator)来持续记录递增状态。
// 一个非常经典的代码,一行实现0-100的和
(0...100).reduce(0, combine: +) // 5050
上边的代码首先是一个(0...100)的数组进行了reduce操作. (0, combine: +)中,0 表示一个初始值,”combine: +“表示对数组中的元素做+运算,得到的结果赋值给0位置的这个参数