Scala语言入门三(集合)

简介: Scala集合的概念和使用

一、数组

Scala 语言中提供的数组是用来存储固定大小的同类型元素,数组对于每一门编辑应语言来说都是重要的数据结构之一。数组的第一个元素索引为0,最后一个元素的索引为元素总数减1

1、声明数组

  • 不可变数组
/**
 * @author Gjing
 **/
object ArrayApp {

  def main(args: Array[String]): Unit = {
    // 声明一个长度为2的不可变数组
    val arr = new Array[String](2)
    // 赋值
    arr(0) = "java"
    arr(1) = "scala"

    // 使用另外一种方式声明数组
    val arr2 = Array("java","scala")
  }
}
  • 不可变数组
/**
 * @author Gjing
 **/
object ArrayApp {

  def main(args: Array[String]): Unit = {
    val buffer = ArrayBuffer[String]()
    // 追加一个值
    buffer += "java"
    // 追加一个数组
    buffer ++= Array("scala", "vue")
  }
}

2、数组的处理

列出常见的一些操作,其余的自行查阅文档

  • 循环输出
/**
 * @author Gjing
 **/
object ArrayApp {

  def main(args: Array[String]): Unit = {
    val arr = Array("java", "scala")
    for (x <- arr) {
      println(x)
    }
  }
}
  • 合并数组
/**
 * @author Gjing
 **/
object ArrayApp {

  def main(args: Array[String]): Unit = {
    val arr = Array("java", "scala")
    val arr2 = Array("vue", "go")
    // 这种方式需要引入 import Array._
    val arr3 = concat(arr, arr2)
    // 直接调用
    val arr4 = arr.concat(arr2)
  }
}

二、List

List的特征是其元素以线性方式存储,集合中可以存放重复对象。

1、创建List

  • 定长list
/**
 * @author Gjing
 **/
object ListApp {

  def main(args: Array[String]): Unit = {
    // 数字列表
    var l1 = List(1, 2, 3, 4)
    var l2 = 1 :: 2 :: 3 :: Nil
    // 生成空列表
    var l3 = Nil
  }
}

构造列表的两个基本单位是 Nil 和 ::

Nil 也可以表示为一个空列表。

  • 不定长
/**
 * @author Gjing
 **/
object ListApp {

  def main(args: Array[String]): Unit = {
    val l = ListBuffer[Int]()
    // 加一个元素
    l += 2
    // 加入多个元素
    l += (3,4)
    // 加入一个集合
    l ++= List(5,6)
    // 打印 2,3,4,5,6
    println(l.mkString(","))
  }
}

2、列表的操作

  • 基本操作(返回第一个元素、返回第一个元素以外的列表、判断列表是否为空)
/**
 * @author Gjing
 **/
object ListApp {

  def main(args: Array[String]): Unit = {
    var l = List(1,2,3)
    // 打印 1
    println(l.head)
    // 打印 List(2,3)
    println(l.tail)
    // 打印false
    println(l.isEmpty)
  }
}
  • 拼接
/**
 * @author Gjing
 **/
object ListApp {

  def main(args: Array[String]): Unit = {
    val l1 = List(1, 2, 3)
    val l2 = List(3,4)
    val l3 = l1 ::: l2
    // 较第一种是后者加进去后再列表前面
    val l4 = l1.:::(l2)
    val l5 = List.concat(l1,l2)
    println(l3.mkString(","))
    println(l4.mkString(","))
    println(l5.mkString(","))
  }
}
  • 列表反转
/**
 * @author Gjing
 **/
object ListApp {

  def main(args: Array[String]): Unit = {
    val l1 = List(1, 2, 3)
    // 打印 3,2,1
    println(l1.reverse.mkString(","))
  }
}
  • 创建一个指定重复数量的元素列表
/**
 * @author Gjing
 **/
object ListApp {

  def main(args: Array[String]): Unit = {
    val l1 = List.fill(2)(1)
    // 打印 1,1
    println(l1.mkString(","))
  }
}

三、Set

Set是最简单的一种集合。集合中的对象不按特定的方式排序,并且没有重复对象, 用法和list差不多,这里不过多介绍

四、Map

Map 是一种把键对象和值对象映射的集合,它的每一个元素都包含一对键对象和值对象。Map 有两种类型,可变与不可变,区别在于可变对象可以修改它,而不可变对象不可以。默认情况下 Scala 使用不可变 Map。如果你需要使用可变集合,你需要显式的引入
import scala.collection.mutable.Map 类在 Scala 中 你可以同时使用可变与不可变 Map,不可变的直接使用 Map,可变的使用 mutable.Map

1、创建Map

/**
 * @author Gjing
 **/
object MapApp {
  def main(args: Array[String]): Unit = {
    // 空map
    val m1 = Map()
    // 存在键值对
    var m2 = Map("名字" -> "张三", "年龄" -> 12)
    println(m2.mkString(","))
    // 加一个新的键值对进去
    m2 += ("性别" -> "男")
    println(m2.mkString(","))
  }
}

2、基本操作

/**
 * @author Gjing
 **/
object MapApp {
  def main(args: Array[String]): Unit = {
    var m2 = Map("名字" -> "张三", "年龄" -> 12)
    // 返回所有key
    println(m2.keys)
    // 返回所有value
    println(m2.values)
    // 判断是否为空
    println(m2.isEmpty)
  }
}

3、合并

你可以使用 ++ 运算符或 Map.++() 方法来连接两个 Map,Map 合并时会移除重复的 key

/**
 * @author Gjing
 **/
object MapApp {
  def main(args: Array[String]): Unit = {
    val map1 = Map("年龄" -> "12")
    val map2 = Map("性别" -> "男")
    println(map1 ++ map2)
    println(map1.++(map2))
  }
}

4、查看 Map 中是否存在指定的 Key

object MapApp {
  def main(args: Array[String]): Unit = {
    var m1 = Map("名字" -> "张三", "年龄" -> 12)
    // 打印 true
    println(m1.contains("名字"))
  }
}

四、元组

元组是不同类型的值的集合,与列表一样,元组也是不可变的,但与列表不同的是元组可以包含不同类型的元素

1、定义元组

/**
 * @author Gjing
 **/
object TupleApp {
  def main(args: Array[String]): Unit = {
    val t1 = (1, "呢", 1.1)
    val t2 = new Tuple3(1, "呢", 1.1)
  }
}

元组的实际类型取决于它的元素的类型,比如 (99, "runoob") 是 Tuple2[Int, String], 目前 Scala 支持的元组最大长度为 22。对于更大长度你可以使用集合,或者扩展元组

2、访问元组

/**
 * @author Gjing
 **/
object TupleApp {
  def main(args: Array[String]): Unit = {
    val t1 = (1, "呢", 1.1)
    // 获取元组第一个内容
    println(t1._1)
    // 获取元组第二个内容
    println(t1._2)
  }
}

3、元组的迭代

/**
 * @author Gjing
 **/
object TupleApp {
  def main(args: Array[String]): Unit = {
    val t1 = (1, "呢", 1.1)
    t1.productIterator.foreach(e => println(e))
  }
}

4、元组转字符串

/**
 * @author Gjing
 **/
object TupleApp {
  def main(args: Array[String]): Unit = {
    val t1 = (1, "呢", 1.1)
    println(t1.toString())
  }
}
目录
相关文章
|
5月前
|
分布式计算 Java Hadoop
Scala入门必刷的100道练习题(附答案)
Scala入门必刷的100道练习题(附答案)
591 1
|
5月前
|
安全 Java Scala
Scala集合【上】
Scala集合【上】
|
5月前
|
Java 大数据 Scala
Scala入门【运算符和流程控制】
Scala入门【运算符和流程控制】
|
11月前
|
Scala
162 Scala 集合
162 Scala 集合
39 0
|
5月前
|
分布式计算 Scala Spark
Scala【集合常用方法和函数操作(下)】
Scala【集合常用方法和函数操作(下)】
|
5月前
|
分布式计算 Scala Spark
Scala 【集合常用方法和函数操作-上】
Scala 【集合常用方法和函数操作-上】
|
2月前
|
监控 安全 Java
Scala 语言助力局域网监控电脑屏幕软件的创新
在数字化办公时代,局域网监控软件对企业和信息安全至关重要。Scala语言融合了面向对象与函数式编程,其简洁的语法和强大的类型系统为这类软件的开发提供了新机遇。利用Scala的函数式编程特性,开发者能编写更简洁、易维护的代码;结合Java的丰富类库,实现高效网络通信;Scala的并发模型还能优化多线程处理,提升监控效率。这些特点使Scala成为开发智能且高效的局域网监控软件的理想选择。
20 0
|
2月前
|
分布式计算 大数据 Java
Scala 入门指南:从零开始的大数据开发
Scala 入门指南:从零开始的大数据开发
|
3月前
|
分布式计算 大数据 Java
大数据开发语言Scala入门
大数据开发语言Scala入门
|
3月前
|
IDE 大数据 Java
「AIGC」大数据开发语言Scala入门
Scala,融合OOP和FP的多范式语言,在JVM上运行,常用于大数据处理,尤其与Apache Spark配合。要开始学习,安装Scala,选择IDE如IntelliJ。基础包括变量、数据类型、控制结构、函数。Scala支持类、对象、不可变数据结构、模式匹配和强大的并发工具。利用官方文档、教程、社区资源进行学习,并通过实践提升技能。
46 0