比较简单,直接上例子
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
object
takeWhileTest {
def
main(args
:
Array[String])
:
Unit
=
{
val
names
=
List(
"spark"
,
"hadoop"
,
"kafka"
,
"hive"
,
"mesos"
,
"zero"
,
"xyz"
,
"marathon"
)
names.takeWhile(
_
.length >
4
).foreach{x
=
> print(x +
" "
)}
println(
"\n------------------"
)
names.take(
2
).foreach{x
=
> print(x +
" "
)}
println(
"\n------------------"
)
names.takeRight(
4
).foreach{x
=
> print(x +
" "
)}
println(
"\n------------------"
)
names.filter(
_
.length >
4
).foreach{x
=
> print(x +
" "
)}
}
}
|
结果:
|
1
2
3
4
5
6
7
|
spark hadoop kafka
------------------
spark hadoop
------------------
mesos zero xyz marathon
------------------
spark hadoop kafka mesos marathon
|
同样,marathon源码中,也有体现,如下:
![001--marathon源码.png wKioL1mx-dSjxajmAAGOQvYOIcw494.png]()
总结:
take(3)---> 表示,取出前3个元素
takeRight(3)----> 表示,从后面/右边开始获取,取出3个元素
takeWhile()---> 表示,从左边开始,将满足条件的元素取出来,直到遇到第一个不满足条件的元素
filter --> 表示,取出所有满足条件的元素
本文转自故新51CTO博客,原文链接:http://blog.51cto.com/xingej/1963582 ,如需转载请自行联系原作者