温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

每天学一点Scala之 take、takeRight、takeWhile 与 filter

发布时间:2020-07-12 14:21:23 来源:网络 阅读:5086 作者:故新 栏目:建站服务器

比较简单,直接上例子

object takeWhileTest {
   def main(args: Array[String]): Unit = {
      val names = List("spark", "hadoop","kafka","hive", "mesos", "zero", "xyz","marathon")
      //需求:将names容器中,获取/过滤出元素长度为4的元素,
      //takeWhile, 从第一个元素开始判断,满足条件,就留下,直到遇到第一个不满足的条件的元素,就结束循环
      //可见,takeWhile 有可能并不是对所有的元素进行操作的
      names.takeWhile(_.length > 4 ).foreach{x => print(x + " ")}

      println("\n------------------")
      //从左边开始获取2个元素,
      names.take(2).foreach{x => print(x + " ")}

      println("\n------------------")

      //从右边开始获取4个元素,
      names.takeRight(4).foreach{x => print(x + " ")}

      println("\n------------------")
      //filter, 同样,满足条件,就留下。是对所有的元素,进行操作的
      names.filter(_.length > 4).foreach{x => print(x + " ")}//将"xyz"元素,过滤掉了
   }
}

结果:

spark hadoop kafka 
------------------
spark hadoop 
------------------
mesos zero xyz marathon 
------------------
spark hadoop kafka mesos marathon


同样,marathon源码中,也有体现,如下:


每天学一点Scala之  take、takeRight、takeWhile 与 filter


总结:

    take(3)---> 表示,取出前3个元素

    takeRight(3)----> 表示,从后面/右边开始获取,取出3个元素

    takeWhile()---> 表示,从左边开始,将满足条件的元素取出来,直到遇到第一个不满足条件的元素

    filter --> 表示,取出所有满足条件的元素






向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI