前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >一天学完spark的Scala基础语法教程九、迭代器(idea版本)

一天学完spark的Scala基础语法教程九、迭代器(idea版本)

作者头像
红目香薰
发布2022-11-29 19:44:47
3670
发布2022-11-29 19:44:47
举报
文章被收录于专栏:CSDNToQQCode

📋前言📋 💝博客主页:红目香薰_CSDN博客-大数据,计算机理论,MySQL领域博主💝 ✍本文由在下【红目香薰】原创,首发于CSDN✍ 🤗2022年最大愿望:【服务百万技术人次】🤗 💝初始环境地址:【spark环境搭建(idea版本)_红目香薰-CSDN博客】💝

环境需求

环境:win10 开发工具:IntelliJ IDEA 2021.2 maven版本:3.6.3

创建测试类【day1/demo9.scalc】,文件类型【object】

Scala Iterator(迭代器)

Scala Iterator(迭代器)不是一个集合,它是一种用于访问集合的方法。

迭代器 it 的两个基本操作是 next 和 hasNext

调用 it.next() 会返回迭代器的下一个元素,并且更新迭代器的状态。

调用 it.hasNext() 用于检测集合中是否还有元素。

让迭代器 it 逐个返回所有元素最简单的方法是使用 while 循环:

代码语言:javascript
复制
package day1

object demo9 {
  def main(args: Array[String]) {
    val it = Iterator("琢石", "璞玉", "破梦", "灭神")

    while (it.hasNext){
      println(it.next())
    }
  }
}

查找最大与最小元素

代码语言:javascript
复制
package day1

object demo9 {
  def main(args: Array[String]) {
    val a = Iterator(20,410,21,50,629, 9110)
    val b = Iterator(20,410,21,50,629, 920)

    println("最大元素是:" + a.max )
    println("最小元素是:" + b.min )
  }
}

获取迭代器的长度

代码语言:javascript
复制
package day1

object demo9 {
  def main(args: Array[String]) {
    val a = Iterator(20,410,21,50,629, 9110)
    val b = Iterator(20,410,21,50,629, 920)

    println("a.size 的值: " + a.size )
    println("b.length 的值: " + b.length )
  }
}

Scala Iterator 常用方法

下表列出了 Scala Iterator 常用的方法:

序号

方法及描述

1

def hasNext: Boolean 如果还有可返回的元素,返回true。

2

def next(): A 返回迭代器的下一个元素,并且更新迭代器的状态

3

def ++(that: => Iterator[A]): Iterator[A] 合并两个迭代器

4

def ++[B >: A](that :=> GenTraversableOnce[B]): Iterator[B] 合并两个迭代器

5

def addString(b: StringBuilder): StringBuilder 添加一个字符串到 StringBuilder b

6

def addString(b: StringBuilder, sep: String): StringBuilder 添加一个字符串到 StringBuilder b,并指定分隔符

7

def buffered: BufferedIterator[A] 迭代器都转换成 BufferedIterator

8

def contains(elem: Any): Boolean 检测迭代器中是否包含指定元素

9

def copyToArray(xs: Array[A], start: Int, len: Int): Unit 将迭代器中选定的值传给数组

10

def count(p: (A) => Boolean): Int 返回迭代器元素中满足条件p的元素总数。

11

def drop(n: Int): Iterator[A] 返回丢弃前n个元素新集合

12

def dropWhile(p: (A) => Boolean): Iterator[A] 从左向右丢弃元素,直到条件p不成立

13

def duplicate: (Iterator[A], Iterator[A]) 生成两个能分别返回迭代器所有元素的迭代器。

14

def exists(p: (A) => Boolean): Boolean 返回一个布尔值,指明迭代器元素中是否存在满足p的元素。

15

def filter(p: (A) => Boolean): Iterator[A] 返回一个新迭代器 ,指向迭代器元素中所有满足条件p的元素。

16

def filterNot(p: (A) => Boolean): Iterator[A] 返回一个迭代器,指向迭代器元素中不满足条件p的元素。

17

def find(p: (A) => Boolean): Option[A] 返回第一个满足p的元素或None。注意:如果找到满足条件的元素,迭代器会被置于该元素之后;如果没有找到,会被置于终点。

18

def flatMap[B](f: (A) => GenTraversableOnce[B]): Iterator[B] 针对迭代器的序列中的每个元素应用函数f,并返回指向结果序列的迭代器。

19

def forall(p: (A) => Boolean): Boolean 返回一个布尔值,指明 it 所指元素是否都满足p。

20

def foreach(f: (A) => Unit): Unit 在迭代器返回的每个元素上执行指定的程序 f

21

def hasDefiniteSize: Boolean 如果迭代器的元素个数有限则返回 true(默认等同于 isEmpty)

22

def indexOf(elem: B): Int 返回迭代器的元素中index等于x的第一个元素。注意:迭代器会越过这个元素。

23

def indexWhere(p: (A) => Boolean): Int 返回迭代器的元素中下标满足条件p的元素。注意:迭代器会越过这个元素。

24

def isEmpty: Boolean 检查it是否为空, 为空返回 true,否则返回false(与hasNext相反)。

25

def isTraversableAgain: Boolean Tests whether this Iterator can be repeatedly traversed.

26

def length: Int 返回迭代器元素的数量。

27

def map[B](f: (A) => B): Iterator[B] 将 it 中的每个元素传入函数 f 后的结果生成新的迭代器。

28

def max: A 返回迭代器迭代器元素中最大的元素。

29

def min: A 返回迭代器迭代器元素中最小的元素。

30

def mkString: String 将迭代器所有元素转换成字符串。

31

def mkString(sep: String): String 将迭代器所有元素转换成字符串,并指定分隔符。

32

def nonEmpty: Boolean 检查容器中是否包含元素(相当于 hasNext)。

33

def padTo(len: Int, elem: A): Iterator[A] 首先返回迭代器所有元素,追加拷贝 elem 直到长度达到 len。

34

def patch(from: Int, patchElems: Iterator[B], replaced: Int): Iterator[B] 返回一个新迭代器,其中自第 from 个元素开始的 replaced 个元素被迭代器所指元素替换。

35

def product: A 返回迭代器所指数值型元素的积。

36

def sameElements(that: Iterator[_]): Boolean 判断迭代器和指定的迭代器参数是否依次返回相同元素

37

def seq: Iterator[A] 返回集合的系列视图

38

def size: Int 返回迭代器的元素数量

39

def slice(from: Int, until: Int): Iterator[A] 返回一个新的迭代器,指向迭代器所指向的序列中从开始于第 from 个元素、结束于第 until 个元素的片段。

40

def sum: A 返回迭代器所指数值型元素的和

41

def take(n: Int): Iterator[A] 返回前 n 个元素的新迭代器。

42

def toArray: Array[A] 将迭代器指向的所有元素归入数组并返回。

43

def toBuffer: Buffer[B] 将迭代器指向的所有元素拷贝至缓冲区 Buffer。

44

def toIterable: Iterable[A] Returns an Iterable containing all elements of this traversable or iterator. This will not terminate for infinite iterators.

45

def toIterator: Iterator[A] 把迭代器的所有元素归入一个Iterator容器并返回。

46

def toList: List[A] 把迭代器的所有元素归入列表并返回

47

def toMap[T, U]: Map[T, U] 将迭代器的所有键值对归入一个Map并返回。

48

def toSeq: Seq[A] 将代器的所有元素归入一个Seq容器并返回。

49

def toString(): String 将迭代器转换为字符串

50

def zip[B](that: Iterator[B]): Iterator[(A, B) 返回一个新迭代器,指向分别由迭代器和指定的迭代器 that 元素一一对应而成的二元组序列

总结

到这里有关一天学完spark的Scala基础语法教程九、迭代器(idea版本)就结束了 希望能对大家有所帮助。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-02-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 环境需求
  • Scala Iterator(迭代器)
  • 查找最大与最小元素
  • 获取迭代器的长度
  • Scala Iterator 常用方法
  • 总结
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档