溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

每天學一點Scala之 take、takeRight、takeWhile 與 filter

發(fā)布時間:2020-07-12 14:21:23 來源:網絡 閱讀:5079 作者:故新 欄目:建站服務器

比較簡單,直接上例子

object takeWhileTest {
   def main(args: Array[String]): Unit = {
      val names = List("spark", "hadoop","kafka","hive", "mesos", "zero", "xyz","marathon")
      //需求:將names容器中,獲取/過濾出元素長度為4的元素,
      //takeWhile, 從第一個元素開始判斷,滿足條件,就留下,直到遇到第一個不滿足的條件的元素,就結束循環(huán)
      //可見,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源碼中,也有體現(xiàn),如下:


每天學一點Scala之  take、takeRight、takeWhile 與 filter


總結:

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

    takeRight(3)----> 表示,從后面/右邊開始獲取,取出3個元素

    takeWhile()---> 表示,從左邊開始,將滿足條件的元素取出來,直到遇到第一個不滿足條件的元素

    filter --> 表示,取出所有滿足條件的元素






向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI