scala函数组合器
1、map
在列表中的每个元素上计算一个函数,并且返回一个包含相同数目元素的列表。
scala> numbers.map(_ * 2)
res3: Array[Int] = Array(2, 4, 6, 8)
2、foreach
和map一样对序列中的每个元素操作,不同的是无返回值
scala> numbers.foreach(println(_))
1
2
3
4
3、filter
移除任何使得传入的函数返回false的元素。返回Boolean类型的函数一般都称为断言函数。
scala> numbers.filter(_ % 2 == 0)
res5: Array[Int] = Array(2, 4)
4、zip
把两个列表的元素合成一个由元素对组成的列表里。
scala> Array(1, 2, 3).zip(Array("one", "two", "three"))
res6: Array[(Int, java.lang.String)] = Array((1,one), (2,two), (3,three))
5、partition
根据断言函数的返回值对列表进行拆分。
scala> val numbers = Array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
numbers: Array[Int] = Array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
scala> numbers.partition(_ % 2 == 0)
res7: (Array[Int], Array[Int]) = (Array(2, 4, 6, 8, 10),Array(1, 3, 5, 7, 9))
6、find
返回集合里第一个匹配断言函数的元素
scala> numbers.find(_ > 5)
res8: Option[Int] = Some(6)
7、drop&dropWhile
drop丢弃前i个元素
scala> numbers.drop(3)
res9: Array[Int] = Array(4, 5, 6, 7, 8, 9, 10)
dropWhile移除前几个匹配断言函数的元素
scala> numbers.dropWhile(_ % 2 != 0)
res11: Array[Int] = Array(2, 3, 4, 5, 6, 7, 8, 9, 10)
8、foldLeft
scala> numbers.foldLeft(0)((a, b) => a + b)
res12: Int = 55
0是起始值
scala> numbers.foldLeft(0){(a, b) => println("a: " + a + " b: " + b); a + b}
a: 0  b: 1
a: 1  b: 2
a: 3  b: 3
a: 6  b: 4
a: 10  b: 5
a: 15  b: 6
a: 21  b: 7
a: 28  b: 8
a: 36  b: 9
a: 45  b: 10
res16: Int = 55
9、foldRight
迭代方向与前者相反
10、flatten
flatten可以把嵌套的结构展开
scala> Array(Array(1, 2), Array(3, 4))
res17: Array[Array[Int]] = Array(Array(1, 2), Array(3, 4))
scala> Array(Array(1, 2), Array(3, 4)).flatten
res18: Array[Int] = Array(1, 2, 3, 4)
11、flatMap
它结合了map和flatten的功能。flatMap接收一个可以处理嵌套列表的函数,然后把返回结果连接起来。
scala> val test = Array(Array(1, 2), Array(3, 4))
test: Array[Array[Int]] = Array(Array(1, 2), Array(3, 4))
scala> test.flatMap(x => x.map(_ * 2))
res20: Array[Int] = Array(2, 4, 6, 8)
scala函数组合器的更多相关文章
- scala进阶笔记:函数组合器(combinator)
		
collection基础参见之前的博文scala快速学习(二). 本文主要是组合器(combinator),因为在实际中发现很有用.主要参考:http://www.importnew.com/3673 ...
 - Java函数接口实现函数组合及装饰器模式
		
摘要: 通过求解 (sinx)^2 + (cosx)^2 = 1 的若干写法,逐步展示了如何从过程式的写法转变到函数式的写法,并说明了编写"[接受函数参数]并返回[能够接受函数参数的函数]的 ...
 - Scala学习(四)——模式匹配与函数组合
		
函数组合 让我们创建两个函数: def f(s: String) = "f(" + s + ")" def g(s: String) = "g(&qu ...
 - Scalaz(14)- Monad:函数组合-Kleisli to Reader
		
Monad Reader就是一种函数的组合.在scalaz里函数(function)本身就是Monad,自然也就是Functor和applicative.我们可以用Monadic方法进行函数组合: i ...
 - 泛函编程(4)-深入Scala函数类
		
既然是泛函编程,多了解一下函数自然是免不了的了: 方法(Method)不等于函数(Function) 方法不是函数但可以转化成函数:可以手工转换或者由编译器(compiler)在适当的情况下自动转换. ...
 - python二 总结--函数-- 装饰器
		
装饰器是什么? 有什么用? 为什么要用? 真的有用吗? 1.装饰器: 装饰器: 定义:本质是函数,(装饰其他函数)就是为其他函数添加附加功能. 原则:1.不能修改被装饰的函数的源代码 ...
 - Scala进阶之路-Scala函数篇详解
		
Scala进阶之路-Scala函数篇详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.传值调用和传名调用 /* @author :yinzhengjie Blog:http: ...
 - 【译】通过 Rust 学习解析器组合器 — Part 1
		
原文地址:Learning Parser Combinators With Rust 原文作者:Bodil 译文出自:掘金翻译计划 本文永久链接:https://github.com/xitu/gol ...
 - 复杂的 Hash 函数组合有意义吗?
		
很久以前看到一篇文章,讲某个大网站储存用户口令时,会经过十分复杂的处理.怎么个复杂记不得了,大概就是先 Hash,结果加上一些特殊字符再 Hash,结果再加上些字符.再倒序.再怎么怎么的.再 Hash ...
 
随机推荐
- Codeforces 452D [模拟][贪心]
			
题意: 给你k件衣服处理,告诉你洗衣机烘干机折叠机的数量,和它们处理一件衣服的时间,要求一件衣服在洗完之后必须立刻烘干,烘干之后必须立刻折叠,问所需的最小时间. 思路: 1.按照时间模拟 2.若洗完的 ...
 - C#中的委托和事件(续)
			
转自张子阳的博客http://www.tracefact.net/CSharp-Programming/Delegates-and-Events-Advanced.aspx 引言 如果你看过了 C#中 ...
 - cocos2d-lua 3.5 android搭建步骤
			
cocos2d-lua 3.5 android搭建步骤 如何安装eclipse,jdk,android sdk,ndk这里都不说了,资料很多,而且以前用eclipse搭建cocos2d-x-c++的时 ...
 - MySQL 密码修改
			
方法1: 用SET PASSWORD命令 首先登录MySQL. 格式:mysql> set password for 用户名@localhost = password('新密码'); 例子:my ...
 - Robotlegs2 学习笔记  --  SwiftSuspenders 2.x (2)
			
Swiftsuspenders2简介 Swiftsuspenders2是一个基于元数据(metadata)的IOC(控制反转,inversion of control)的AS3的解决方案.(对于元数据 ...
 - 让Windows7运行速度更快的BIOS优化设置教程
			
和以前使用WindowsXP一样,很多用户都在设法提高windows7的系统运行速速,比较常见的方法大多是对系统服务进行优化,去掉一些可有可无的系统服务,还有就是优化资源管理器菜单等.除此之外,还有一 ...
 - 构造一个简单的linux系统
			
1.搭建环境 cd ~/Work/ wget https://www.kernel.org/pub/linux/kernel/v3.x/linux-3.18.6.tar.xz xz -d linux- ...
 - php函数将对象转换为数组以及json_decode的使用技巧
			
在写php代码的时候,发现调用接口返回的结果类型是对象,不是自己想要的数组,于是乎,写了一个将对象转化数组的函数: /** * 将对象转化为数组 */ private function objectT ...
 - CSS3之弹性布局
			
flexbox是CSS3提出的页面布局模块.flexbox可以把列表横向或者纵向排列,并且填满可以延伸到的空间.稍微复杂的布局可以通过嵌套flex container来实现. 利用flexbox可以方 ...
 - sqlmap.config 配置
			
<?xml version="1.0" encoding="utf-8"?> <sqlMapConfig xmlns="http:/ ...