Scala Map和Flatmap的用法

代码如下:

package demo.map_and_flatmap

object MapAndFlatMapDemo {
 
def main(args: Array[String]): Unit = {
   
/**--------map对传入的每一个元素进行映射,返回一个处理后的结果(begin)-----------------**/
   
//完整版
   
val arr1 = Array(1,2,3,4,5).map(x=>2* x)
    arr1.foreach(x => print(x +
"\t"))
    println()
   
//简写版
   
Array(1,2,3,4,5).map(2* _).foreach(x => print(x + "\t"))
    println()
   
//foreach对传入的每一个元素都进行处理,但是没有返回值
   
(1 to 9 ).map("@"*_).foreach(println(_))
   
//filter:对传入的每一个元素都进行条件判断,如果返回true,则保留该元素,否则过滤掉该元素
   
val rdd1 = (1 to 20 ).filter(_%2==0)
    rdd1.foreach(x=>{
val y=x+"\t";print(y)})
    println()

   
/**flatMapmap的一种扩展。在flatMap中,我们会传入一个函数,该函数对每个输入都会返回一个集合(而不是一个元素),然后,flatMap把生成的多个集合拍扁成为一个集合。*/
   
val books = List("Hadoop","Hive","HDFS")
   
val charList = books.flatMap(elem=>elem.toList)
    println(charList)
    charList.foreach(print(_))
  }
}


运行结果:

2    4    6    8    10    
2    4    6    8    10    
@
@@
@@@
@@@@
@@@@@
@@@@@@
@@@@@@@
@@@@@@@@
@@@@@@@@@
2    4    6    8    10    12    14    16    18    20    
List(H, a, d, o, o, p, H, i, v, e, H, D, F, S)
HadoopHiveHDFS
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值