1. Scala 的面向对象

在学习 Java 的时候,我们说 Java 是一门面向对象的语言,然而 Java 其实并没有完全遵守“一切皆对象”这一准则。

例如:Java 的8种基本数据类型 & Java 的数组。

但是 Scala 相比而言,是一门更加纯粹的面向对象的语言,因为它完全遵守“一切皆对象”。

2. 数组 Array

Scala 中定义了数组对象 scala.Array。

我们可以这么初始化一个数组对象:

val array = new Array[String](3)

它的类型是 Array[String],所以也可以这么定义(不使用类型推断)

val array: Array[String] = new Array[String](3)

如果需要在创建和初始化数组的同时,对其中所有的元素进行赋值,也可以这么做:

val array = Array("1", "2", "3")

这么做从语法上看,可能会有点奇怪,但是它会在编译时调用 Array 伴生对象里一个 apply() 的工厂方法,所以其实质是:

val array = Array.apply("1", "2", "3")

Scala 中使用圆括号 () 而不是方括号[] 来调用数组中的元素:

for (i <- 0 to 2) println(array(i))

这么做的原因也是为了契合 Scala 面向对象的特点,它本质上是调用 Array 对象的 apply() 方法:

for (i <- 0 to 2) println(array.apply(i))

Scala 的数组允许更新其中的元素内容:

array(0) = "0"

它本质上是调用 Array 对象的 update() 方法:

array.update(0, "0")

由此可见,Scala 数组是一个拥有相同类型对象的可变序列,虽然无法在数组实例化之后改变其长度,但是可以改变元素值,所以 Array 是一个可变对象

3. 列表 List

与数组相对,列表 List 是一个拥有相同类型,即不可改变其长度,又不可改变其元素值得数据结构。

Scala 的 List 与 Java 的 List 不同,它是一个不可变对象

所以 List 必须在初始化的同时,将 List 里面所有的元素同时完成初始化:

val list = List(1, 2)

val list = List.apply(1, 2) // 与上面等价

由于是不可变对象,List 只能读取不可修改,读取方式和 Array 相同:

for (i <- 0 to 1) println(list(i))
for (i <- 0 to 1) println(list.apply(i)) // 与上面等价

列表 List 支持 :: 和 ::: 操作符来对列表进行拼接。

(Scala 支持使用纯操作符,来作为函数的名字,而这个操作符如果以 : 结尾,那么就认为是右操作元方法,即函数的调用发生在操作符的右侧对象上,反之则是左操作元方法)

双冒号操作符方法,用于在列表最前面添加一个新的元素,返回新的列表:

val list2 = 0 :: list // 结果是 List(0, 1, 2)
val list2 = list.::(0) // 与上面等价

三冒号操作符方法,用于拼接两个列表,返回新的列表:

val list1 = List(1, 2)
val list2 = List(3, 4)
val list3 = list1 ::: list2 // 结果是 List(1, 2, 3, 4)
val list3 = list2.:::(list1) // 与上面等价

空列表用 Nil 表示,通过巧妙地使用 Nil,增加了新的创建列表 List 对象的方式:

val list = 1 :: 2 :: Nil // 结果是 List(1, 2)

4. 元组 Tuple

Array 和 List 都是只能存储同一种数据类型,元组 Tuple 支持存储不同的数据类型。

元组是不可变对象

元组只有一种初始化方式:

val pair = (1, "Two", Array(1, 2), List("one"))
val pair = Tuple4.apply(1, "Two", Array(1, 2), List("one")) // 与上面等价

Scala 源码中,根据元组的长度,创建了22个对象,从 Tuple1 到 Tuple22。

访问元组元素的方法,是通过英文句点. & 下划线_ & 从1开始的序号:

println(pair._1)
println(pair._2)
  • 之所以不能使用类似 pair(1) 来访问元素,是因为 apply() 方法在元组中,不能确定结果类型。
  • 之所以从下标1开始访问元组的元素,是为了兼容其他支持元组的语言的使用习惯。

5. 集 Set

与 Java 类似, Scala 中提供集 Set 来存储同一类型、不含重复元素的集合。

Scala 提供了两种集,可变集 scala.collection.mutable.Set 和不可变集  scala.collection.immutable.Set。

其中,不可变集在没有 import 的情况下,为默认实现。

这里的可变性在于:Set 的长度可变,但是每一个元素指向的内容还是不可变的。

集 Set 的初始化方式:

val set = Set("1", "23", "1")
val set = Set.apply("1", "23", "1") // 与上面等价

集 Set 不能通过下标来读取里面的内容,其默认的 apply() 方法的作用是判断入参是否存在于集对象中:

set("1") // 返回 true

如果需要读取 Set 中的元素,需要用到迭代器:

set.foreach(s => println(s))

可以使用 += 来为 Set 添加新的元素

var set = Set("1", "23", "1") // 这里必须定义成 var,因为是不可变 Set
set += "33"
val set = scala.collection.mutable.Set("1", "23", "1")
set += "33"

6. 映射 Map

Map 映射用来存储两个对象之间的映射关系。

和 Set 相同,Scala 提供了可变映射 scala.collection.mutable.Map 和不可变映射  scala.collection.immutable.Map,不可变映射为默认实现。

映射 Map 的初始化方式,通过 -> 表达映射关系:

val map = Map(1 -> "1", 2 -> "2")

通过 += 操作符为 Map 添加映射关系:

var map = Map(1 -> "1", 2 -> "2") // 因为不可变 Map,所以必须是 var
map += 1 -> "0"

如果 添加的 key 值相同,后者会取代前者,例如下面的例子输出就是0:

var map = Map(1 -> "1", 2 -> "2")
map += 1 -> "0"
println(map.apply(1))

Scala 基础(2)—— 基本数据结构的更多相关文章

  1. (数据科学学习手札45)Scala基础知识

    一.简介 由于Spark主要是由Scala编写的,虽然Python和R也各自有对Spark的支撑包,但支持程度远不及Scala,所以要想更好的学习Spark,就必须熟练掌握Scala编程语言,Scal ...

  2. 第一章 Scala基础篇

    目录 一.Scala基础语法 (一) 变量.类型.操作符 1.变量申明 2.字符串 3.数据类型 4.操作符 (二)循环判断 1.块表达式 2.条件表达式 3.循环表达式 (三)方法和函数 1.方法 ...

  3. 【Scala学习之一】 Scala基础语法

    环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk1.8 scala-2.10.4(依赖jdk1.8) spark ...

  4. Scala学习(一)--Scala基础学习

    Scala基础学习 摘要: 在篇主要内容:如何把Scala当做工业级的便携计算器使用,如何用Scala处理数字以及其他算术操作.在这个过程中,我们将介绍一系列重要的Scala概念和惯用法.同时你还将学 ...

  5. Scala基础(1)

    Scala基础语法 声明与定义: val,常量声明                       val  x:T(把x声明成一个类型为T的常量)  x是变量的名字,T是变量的类型          v ...

  6. scala 基础知识总结

    在最开始处引入 log 相关的 包 import org.apache.log4j.{Logger,Level} 在需要屏蔽日志输出的地方加上这两行代码 // 屏蔽不必要的日志显示在终端上 Logge ...

  7. 1.scala基础语法总结

    Scala基础语法总结:Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的.如果一行里写多个语句那么分号是需要的 val s = "菜鸟教程"; pr ...

  8. Scala 基础(8)—— 占位符_和部分应用函数

    1. 占位符 _ 针对 Scala 基础(7)—— 函数字面量和一等函数 中最后提到的,关于 filter 函数字面量的精简写法,可以使用占位符 _ 来代替. 占位符_,用来表示一个或者多个参数.(这 ...

  9. Scala 基础(7)—— 函数字面量和一等函数

    1. 函数字面量 在 Scala 基础(3)—— 基础类型和基础操作 中提到了函数字面量,这里具体解释函数字面量的语法. 下面展示一个具体的函数字面量,它由三部分组成: (x: Int, y: Int ...

  10. Scala 基础(5)—— 构建函数式对象

    有了 Scala 基础(4)—— 类和对象 的前提,现在就可以来构建一个基于 Scala 的函数式对象. 下面开始构造一个有理数对象 Rational. 1. 主构造方法和辅助构造方法 对于每一个类的 ...

随机推荐

  1. javascript入门笔记8-window对象

    History 对象 history对象记录了用户曾经浏览过的页面(URL),并可以实现浏览器前进与后退相似导航的功能. 注意:从窗口被打开的那一刻开始记录,每个浏览器窗口.每个标签页乃至每个框架,都 ...

  2. mycat特点及用途

    Mycat关键特性 关键特性 支持SQL92标准 遵守Mysql原生协议,跨语言,跨平台,跨数据库的通用中间件代理. 基于心跳的自动故障切换,支持读写分离,支持MySQL主从,以及galera clu ...

  3. fastjson 应用

    fastjson优势就是解析快,用法和json-lib.jar差不多(如下图) 贴心的附上jar和反编译工具:https://pan.baidu.com/s/1iADAiFyoUZVBAFSPsIeY ...

  4. 用Java读取xml文件内容

     在AXP中,DOM解析器是1 Document Builder类的一个实例,该实例由 DocumenBailderfactorv类负责创,步如下  DocumentBuilderFactory fa ...

  5. django+xadmin在线教育平台(八)

    4-5 user modesl.py设计 循环引用: 设计app时每个app都有model   mark 如图:我们在user中定义usercourse记录用户学习的课程.会有两个外键:user和co ...

  6. IDEA的下载安装和激活

    1.下载网站http://www.jetbrains.com/ 2. 3. 4.注意要下载Ultimate版本 5.安装 下载完成后直接下一步,傻瓜式安装 6.激活,在图片位置输入激活码即可 !!!! ...

  7. ubuntu18.04.1LTS系统远程工具secureCRT

    ubuntu18.04.1LTS类windows的系统下安装远程管理工具 本地电脑之前安装的是win10,疲于win10频繁的更新和各种兼容问题,果断放弃win10系统,安装了Ubuntu 18.04 ...

  8. pycharm中文乱码问题 总结

    前言: 这几天刚刚开始学习python,然后就安装了pycharm,但是那个中文乱码的问题真是让人心烦,在网上找了好久,都写得好乱,今天终于让我解决了,在这里总结一下经验,希望可以帮到你们 问题:如下 ...

  9. 为 vsftpd 启动 vsftpd:500 OOPS: SSL: cannot load RSA&nb

    博主在配置ftp服务器的时候 自己生成的CA,然后认证自己的私钥文件 一切配置都是没有问题的,然后重新启动服务器 service vsftpd restart    出现以下错误 为 vsftpd 启 ...

  10. POJ:3292-Semi-prime H-numbers(艾氏筛选法拓展)

    Semi-prime H-numbers Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 10466 Accepted: 4665 ...