scala常用函数

1.过滤:filter
val list1 = List(1,2,3,4,5,6,7,8,9)
val list2  = list1.filter(_%2==0)

2.foreach  (注意和map的区别)
val list3 = List(32,12,56,98,3)
注:如果用map遍历会产生空的数组
list3.map(x => println(x))
但是foreach就不会
list3.foreach(x => println(x))

3.化简:reduce
val list = List(1,2,3,4,5)
list.reduce(_+_)
注意:底层调用的reduceLeft

4.集合并行化(计算机多核多线程操作 不指定并行任务 和计算机的核数有关)
val list = List(1,2,3,4,5)
list.par
注意:reduce支持并行计算
list.par.reduce(_+_)

5.折叠 fold 指定初始值 同样支持并行运算
list.par.fold(0)(_+_)
注意:如果不是并行运算 调用的是foldLeft()()

6.聚合(局部求和 再汇总)  
val arr = List(List(1, 2, 3), List(3, 4, 5), List(2), List(0))
   
arr.par //之后才可以并行运算

  
arr.aggregate(0)(_+_.reduce(_+_),_+_)
arr.aggregate(10)(_+_.sum,_+_)
arr.par.aggregate(10)(_+_.sum,_+_)

7.集合并交差
val l1 = List(5,6,4,7)
    
val l2 = List(1,2,3,4)
 

7.1 求并集 l1.union(l2)  合并他俩 list是有序 可重复的 所有结果是 1 2 3 4 5 6 4 7
7.2 求交集 l1.intersect(l2)  公有的 4
7.3 求差集 l1.diff(l2) 基于l1 看l2中没有的都是    5 6 7
 



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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值