Swift - 高阶函数介绍(map、flatMap、filter、reduce) 原文出自:www.hangge.com 转载请保留原文链接:http://www.hangge.com/blog/

本文主要是介绍Swift - 高阶函数介绍(map、flatMap、filter、reduce) 原文出自:www.hangge.com 转载请保留原文链接:http://www.hangge.com/blog/,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://www.hangge.com/blog/cache/detail_1827.html

Swift 提供了如下几个高阶函数:map、flatMap、filter、reduce。使用高阶函数进行函数式编程不仅可以简化我们的代码,而且当数据比较大的时候,高阶函数会比传统实现更快,因为它可以并行执行(如运行在多核上)。

 

一、map 函数

1,方法介绍

map 方法获取一个闭包表达式作为其唯一参数。 数组中的每一个元素调用一次该闭包函数,并返回该元素所映射的值。

简单说就是数组中每个元素通过某个方法进行转换,最后返回一个新的数组。

 

2,使用样例

(1)下面将 Int 类型数组(各个商品的金额),转换成 String 类型的数组(在金额前加上 $ 符号)

1

2

3

let prices = [20,30,40]

let strs = prices.map({ "$\($0)" })

print(strs)

原文:Swift - 高阶函数介绍(map、flatMap、filter、reduce)

 

(2)对一个数组里面的数据进行平方操作

1

2

3

let values = [4, 6, 9]

let squares = values.map({ $0 * $0 })

print(squares)

原文:Swift - 高阶函数介绍(map、flatMap、filter、reduce)

 

二、flatMap 函数

1,方法介绍

flatMap 方法同 map 方法比较类似,只不过它返回后的数组中不存在 nil(自动把 nil 给剔除掉),同时它会把 Optional 解包。

 

2,使用样例

(1)下面比较 map 和 flatMap 这两个方法

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

let array = ["Apple""Orange""Grape"""]

 

let arr1 = array.map { a -> Intin

    let length = a.count

    guard length > 0 else return nil }

    return length

}

print("arr1:\(arr1)")

 

let arr2 = array.flatMap { a-> Intin

    let length = a.count

    guard length > 0 else return nil }

    return length

}

print("arr2:\(arr2)")

原文:Swift - 高阶函数介绍(map、flatMap、filter、reduce)

 

(2)flatMap 还能把数组中存有数组的数组(二维数组、N维数组)一同打开变成一个新的数组。

1

2

3

let array = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]

let arr1 = array.map{ $0 }   // [[1, 2, 3], [4, 5, 6], [7, 8, 9]]

let arr2 = array.flatMap{ $0 } // [1, 2, 3, 4, 5, 6, 7, 8, 9]

 

三、filter 函数

1,方法介绍

filter 方法用于过滤元素,即筛选出数组元素中满足某种条件的元素。

 

2,使用样例

(1)筛选出金额大于 25 的元素。

1

2

3

let prices = [20,30,40]

let result = prices.filter({ $0 > 25 })

print(result)

原文:Swift - 高阶函数介绍(map、flatMap、filter、reduce)

 

四、reduce 函数

1,方法介绍

reduce 方法把数组元素组合计算为一个值,并且会接受一个初始值,这个初始值的类型可以和数组元素类型不同。

 

2,使用样例

(1)将数组中的金额相加,计算总和。

1

2

3

let prices = [20,30,40]

let sum = prices.reduce(0) { $0 + $1 }

print(sum)

原文:Swift - 高阶函数介绍(map、flatMap、filter、reduce)

 

注意:上面计算总数代码还可以简化成如下代码:

1

let sum = prices.reduce(0, +)


(2)将数组转成字符串,每个元素用顿号(、)隔开。

1

2

3

4

5

6

7

8

let array = ["Apple""Orange""Grape"]

let str = array.reduce("", {

    return $0 == "" ? $1 : $0 + "、" + $1

})

print(str)

 

//上面等效与

let str = array.joined(separator: "、")

原文:Swift - 高阶函数介绍(map、flatMap、filter、reduce)

 

五、高阶函数的组合使用、链式调用

1,组合使用

(1)flatMap 配合 filter 将多维整型数组里面的偶数筛选出来并且组合成了一个一维数组。

1

2

3

4

5

let collections = [[5,2,7],[4,8],[9,1,3]]

let onlyEven = collections.flatMap {

    $0.filter { $0 % 2 == 0 }

}

print(onlyEven)

原文:Swift - 高阶函数介绍(map、flatMap、filter、reduce)

 

(2)map 配合 reduce 计算二维数组里每个分组的总和。

1

2

3

let collections = [[5,2,7],[4,8],[9,1,3]]

let sums = collections.map({ $0.reduce(0, +) })

print(sums)

原文:Swift - 高阶函数介绍(map、flatMap、filter、reduce)

 

2,链式组合

(1)将数组中大于 7 的所有数字进行求和操作。

1

2

let marks = [4,5,8,2,9,7]

let totalPass = marks.filter{$0 > 7}.reduce(0,+) //17


(2)对某一个数组里面的数字进行平方操作然后再筛选出偶数值。

1

2

let numbers = [4,5,8,2,9,7]

let evenSquares = numbers.map{$0 * $0}.filter{$0 % 2 == 0} //[16, 64, 4]


原文出自:www.hangge.com  转载请保留原文链接:http://www.hangge.com/blog/cache/detail_1827.html

这篇关于Swift - 高阶函数介绍(map、flatMap、filter、reduce) 原文出自:www.hangge.com 转载请保留原文链接:http://www.hangge.com/blog/的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/712609

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串