val strList= "abc" :: ("def" :: ("gh" :: Nil))
val nums = 1 :: (2 :: (3 :: (4 :: Nil)))
val empty = Nil
val dim = (1 :: (0 :: (0 :: Nil))) ::
(0 :: (1 :: (0 :: Nil))) ::
(0 :: (0 :: (1 :: Nil))) :: Nil
| 序号 | 方法及描述 |
|---|---|
| 1 |
def +:(elem: A): List[A] 为列表预添加元素 scala> val x = List(1) x: List[Int] = List(1) scala> val y = 2 +: x y: List[Int] = List(2, 1) scala> println(x) List(1) |
| 2 |
def ::(x: A): List[A] 在列表开头添加元素 |
| 3 |
def :::(prefix: List[A]): List[A] 在列表开头添加指定列表的元素 |
| 4 |
def :+(elem: A): List[A] 复制添加元素后列表。 scala> val a = List(1) a: List[Int] = List(1) scala> val b = a :+ 2 b: List[Int] = List(1, 2) scala> println(a) List(1) |
| 5 |
def addString(b: StringBuilder): StringBuilder 将列表的所有元素添加到 StringBuilder |
| 6 |
def addString(b: StringBuilder, sep: String): StringBuilder 将列表的所有元素添加到 StringBuilder,并指定分隔符 |
| 7 |
def apply(n: Int): A 通过列表索引获取元素 |
| 8 |
def contains(elem: Any): Boolean 检测列表中是否包含指定的元素 |
| 9 |
def copyToArray(xs: Array[A], start: Int, len: Int): Unit 将列表的元素复制到数组中。 |
| 10 |
def distinct: List[A] 去除列表的重复元素,并返回新列表 |
| 11 |
def drop(n: Int): List[A] 丢弃前n个元素,并返回新列表 |
| 12 |
def dropRight(n: Int): List[A] 丢弃最后n个元素,并返回新列表 |
| 13 |
def dropWhile(p: (A) => Boolean): List[A] 从左向右丢弃元素,直到条件p不成立 |
| 14 |
def endsWith[B](that: Seq[B]): Boolean 检测列表是否以指定序列结尾 |
| 15 |
def equals(that: Any): Boolean 判断是否相等 |
| 16 |
def exists(p: (A) => Boolean): Boolean 判断列表中指定条件的元素是否存在。 判断l是否存在某个元素: scala> l.exists(s => s == "Hah") res7: Boolean = true |
| 17 |
def filter(p: (A) => Boolean): List[A] 输出符号指定条件的所有元素。 过滤出长度为3的元素: scala> l.filter(s => s.length == 3) res8: List[String] = List(Hah, WOW) |
| 18 |
def forall(p: (A) => Boolean): Boolean 检测所有元素。 例如:判断所有元素是否以"H"开头: scala> l.forall(s => s.startsWith("H")) res10: Boolean = false |
| 19 |
def foreach(f: (A) => Unit): Unit 将函数应用到列表的所有元素 |
| 20 |
def head: A 获取列表的第一个元素 |
| 21 |
def indexOf(elem: A, from: Int): Int 从指定位置 from 开始查找元素第一次出现的位置 |
| 22 |
def init: List[A] 返回所有元素,除了最后一个 |
| 23 |
def intersect(that: Seq[A]): List[A] 计算多个集合的交集 |
| 24 |
def isEmpty: Boolean 检测列表是否为空 |
| 25 |
def iterator: Iterator[A] 创建一个新的迭代器来迭代元素 |
| 26 |
def last: A 返回最后一个元素 |
| 27 |
def lastIndexOf(elem: A, end: Int): Int 在指定的位置 end 开始查找元素最后出现的位置 |
| 28 |
def length: Int 返回列表长度 |
| 29 |
def map[B](f: (A) => B): List[B] 通过给定的方法将所有元素重新计算 |
| 30 |
def max: A 查找最大元素 |
| 31 |
def min: A 查找最小元素 |
| 32 |
def mkString: String 列表所有元素作为字符串显示 |
| 33 |
def mkString(sep: String): String 使用分隔符将列表所有元素作为字符串显示 |
| 34 |
def reverse: List[A] 列表反转 |
| 35 |
def sorted[B >: A]: List[A] 列表排序 |
| 36 |
def startsWith[B](that: Seq[B], offset: Int): Boolean 检测列表在指定位置是否包含指定序列 |
| 37 |
def sum: A 计算集合元素之和 |
| 38 |
def tail: List[A] 返回所有元素,除了第一个 |
| 39 |
def take(n: Int): List[A] 提取列表的前n个元素 |
| 40 |
def takeRight(n: Int): List[A] 提取列表的后n个元素 |
| 41 |
def toArray: Array[A] 列表转换为数组 |
| 42 |
def toBuffer[B >: A]: Buffer[B] 返回缓冲区,包含了列表的所有元素 |
| 43 |
def toMap[T, U]: Map[T, U] List 转换为 Map |
| 44 |
def toSeq: Seq[A] List 转换为 Seq |
| 45 |
def toSet[B >: A]: Set[B] List 转换为 Set |
| 46 |
def toString(): String 列表转换为字符串 |
本文深入讲解Scala中的列表,包括List的基本定义、构造方法如`Nil`和`::`,以及如何创建填充相同元素的列表。还探讨了列表的操作,如head、tail、isEmpty、连接和反转等,帮助理解Scala列表的特性和使用技巧。

被折叠的 条评论
为什么被折叠?



