一、定长数组

在Scala中,如果你需要一个长度不变的数组,可以使用Array。但需要注意以下两点:

  • 在Scala中使用(index)而不是[index]来访问数组中的元素,因为访问元素,对于Scala来说是方法调用,(index)相当于执行了.apply(index)方法。
  • Scala中的数组与Java中的是等价的,Array[Int]()在虚拟机层面就等价于Java的int[]
  1. // 10个整数的数组,所有元素初始化为0
  2. scala> val nums=new Array[Int](10)
  3. nums: Array[Int] = Array(0, 0, 0, 0, 0, 0, 0, 0, 0, 0)
  4. // 10个元素的字符串数组,所有元素初始化为null
  5. scala> val strings=new Array[String](10)
  6. strings: Array[String] = Array(null, null, null, null, null, null, null, null, null, null)
  7. // 使用指定值初始化,此时不需要new关键字
  8. scala> val a=Array("hello","scala")
  9. a: Array[String] = Array(hello, scala)
  10. // 使用()来访问元素
  11. scala> a(0)
  12. res3: String = hello

二、变长数组

在scala中通过ArrayBuffer实现变长数组(又称缓冲数组)。在构建ArrayBuffer时必须给出类型参数,但不必指定长度,因为ArrayBuffer会在需要的时候自动扩容和缩容。变长数组的构建方式及常用操作如下:

  1. import scala.collection.mutable.ArrayBuffer
  2. object ScalaApp {
  3. // 相当于Java中的main方法
  4. def main(args: Array[String]): Unit = {
  5. // 1.声明变长数组(缓冲数组)
  6. val ab = new ArrayBuffer[Int]()
  7. // 2.在末端增加元素
  8. ab += 1
  9. // 3.在末端添加多个元素
  10. ab += (2, 3, 4)
  11. // 4.可以使用++=追加任何集合
  12. ab ++= Array(5, 6, 7)
  13. // 5.缓冲数组可以直接打印查看
  14. println(ab)
  15. // 6.移除最后三个元素
  16. ab.trimEnd(3)
  17. // 7.在第1个元素之后插入多个新元素
  18. ab.insert(1, 8, 9)
  19. // 8.从第2个元素开始,移除3个元素,不指定第二个参数的话,默认值为1
  20. ab.remove(2, 3)
  21. // 9.缓冲数组转定长数组
  22. val abToA = ab.toArray
  23. // 10. 定长数组打印为其hashcode值
  24. println(abToA)
  25. // 11. 定长数组转缓冲数组
  26. val aToAb = abToA.toBuffer
  27. }
  28. }

需要注意的是:使用+=在末尾插入元素是一个高效的操作,其时间复杂度是O(1)。而使用insert随机插入元素的时间复杂度是O(n),因为在其插入位置之后的所有元素都要进行对应的后移,所以在ArrayBuffer中随机插入元素是一个低效的操作。

三、数组遍历

  1. object ScalaApp extends App {
  2. val a = Array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
  3. // 1.方式一 相当于Java中的增强for循环
  4. for (elem <- a) {
  5. print(elem)
  6. }
  7. // 2.方式二
  8. for (index <- 0 until a.length) {
  9. print(a(index))
  10. }
  11. // 3.方式三, 是第二种方式的简写
  12. for (index <- a.indices) {
  13. print(a(index))
  14. }
  15. // 4.反向遍历
  16. for (index <- a.indices.reverse) {
  17. print(a(index))
  18. }
  19. }

这里我们没有将代码写在main方法中,而是继承自App.scala,这是Scala提供的一种简写方式,此时将代码写在类中,等价于写在main方法中,直接运行该类即可。

四、数组转换

数组转换是指由现有数组产生新的数组。假设当前拥有a数组,想把a中的偶数元素乘以10后产生一个新的数组,可以采用下面两种方式来实现:

  1. object ScalaApp extends App {
  2. val a = Array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
  3. // 1.方式一 yield关键字
  4. val ints1 = for (elem <- a if elem % 2 == 0) yield 10 * elem
  5. for (elem <- ints1) {
  6. println(elem)
  7. }
  8. // 2.方式二 采用函数式编程的方式,这和Java 8中的函数式编程是类似的,这里采用下划线标表示其中的每个元素
  9. val ints2 = a.filter(_ % 2 == 0).map(_ * 10)
  10. for (elem <- ints1) {
  11. println(elem)
  12. }
  13. }

五、多维数组

和Java中一样,多维数组由单维数组组成。

  1. object ScalaApp extends App {
  2. val matrix = Array(Array(11, 12, 13, 14, 15, 16, 17, 18, 19, 20),
  3. Array(21, 22, 23, 24, 25, 26, 27, 28, 29, 30),
  4. Array(31, 32, 33, 34, 35, 36, 37, 38, 39, 40))
  5. for (elem <- matrix) {
  6. for (elem <- elem) {
  7. print(elem + "-")
  8. }
  9. println()
  10. }
  11. }
  12. 打印输出如下:
  13. 11-12-13-14-15-16-17-18-19-20-
  14. 21-22-23-24-25-26-27-28-29-30-
  15. 31-32-33-34-35-36-37-38-39-40-

六、与Java互操作

由于Scala的数组是使用Java的数组来实现的,所以两者之间可以相互转换。

  1. import java.util
  2. import scala.collection.mutable.ArrayBuffer
  3. import scala.collection.{JavaConverters, mutable}
  4. object ScalaApp extends App {
  5. val element = ArrayBuffer("hadoop", "spark", "storm")
  6. // Scala转Java
  7. val javaList: util.List[String] = JavaConverters.bufferAsJavaList(element)
  8. // Java转Scala
  9. val scalaBuffer: mutable.Buffer[String] = JavaConverters.asScalaBuffer(javaList)
  10. for (elem <- scalaBuffer) {
  11. println(elem)
  12. }
  13. }

参考资料

  1. Martin Odersky . Scala编程(第3版)[M] . 电子工业出版社 . 2018-1-1
  2. 凯.S.霍斯特曼 . 快学Scala(第2版)[M] . 电子工业出版社 . 2017-7

更多大数据系列文章可以参见个人 GitHub 开源项目: 程序员大数据入门指南

Scala 学习之路(四)—— 数组Array的更多相关文章

  1. Scala学习笔记(四)—— 数组

    定长数组Array 定义定长数组用Array,有如下几种方法: 初始化一个长度为8的定长数组,其所有元素默认值均为0 scala> new Array[Int](8) res0: Array[I ...

  2. Scala学习之路----基础入门

    一.Scala解释器的使用 REPL:Read(取值)-> Evaluation(求值)-> Print(打印)-> Loop(循环) scala解释器也被称为REPL,会快速编译s ...

  3. Scala学习之路 (三)Scala的基本使用

    一.Scala概述 scala是一门多范式编程语言,集成了面向对象编程和函数式编程等多种特性.scala运行在虚拟机上,并兼容现有的Java程序.Scala源代码被编译成java字节码,所以运行在JV ...

  4. Fortran学习笔记:03 数组(Array)

    Fortran学习笔记目录 书接上回:Fortran学习笔记:02 流控制语句 数组(Array) 定义数组 一维数组 program main implicit none integer :: i ...

  5. Redis——学习之路四(初识主从配置)

    首先我们配置一台master服务器,两台slave服务器.master服务器配置就是默认配置 端口为6379,添加就一个密码CeshiPassword,然后启动master服务器. 两台slave服务 ...

  6. Scala学习之路 (四)Scala的数组、映射、元组、集合

    一.数组 1.定长数组和变长数组 import scala.collection.mutable.ArrayBuffer object TestScala { def main(args: Array ...

  7. Scala 学习之路(十二)—— 类型参数

    一.泛型 Scala支持类型参数化,使得我们能够编写泛型程序. 1.1 泛型类 Java中使用<>符号来包含定义的类型参数,Scala则使用[]. class Pair[T, S](val ...

  8. Scala 学习之路(六)—— 常用集合类型之 List & Set

    一.List字面量 List是Scala中非常重要的一个数据结构,其与Array(数组)非常类似,但是List是不可变的,和Java中的List一样,其底层实现是链表. scala> val l ...

  9. Scala 学习之路(五)—— 集合类型综述

    一.集合简介 Scala中拥有多种集合类型,主要分为可变的和不可变的集合两大类: 可变集合: 可以被修改.即可以更改,添加,删除集合中的元素: 不可变集合类:不能被修改.对集合执行更改,添加或删除操作 ...

随机推荐

  1. Android, iOS, 各种软件汇总

    Android: 长截图:软件叫PPIICC的可以截图之后拼接:有些手机自带截图,比如小米,华为,三星等. 视频:全格式的Kodi XBMC, 一般的:moboplayer, VLC, F蔷:***, ...

  2. 在WPF设计工具Blend2中制作立方体图片效果

    原文:在WPF设计工具Blend2中制作立方体图片效果 ------------------------------------------------------------------------ ...

  3. 黑科技 —— OTG 线

    OTG:On-The-Go的缩写: OTG 可将鼠标.键盘等一切终端(terminal)连接起来: OTG 技术就是实现在没有 Host 的情况下,实现从设备间的数据传送.(支持传送,显然也支持要求更 ...

  4. Python抓取小说

    Python抓取小说 前言 这个脚本命令MAC在抓取小说写,使用Python它有几个码. 代码 # coding=utf-8 import re import urllib2 import chard ...

  5. scipy —— 丰富的子包(io、cluster)

    io,顾名思义,input/output,输入输出接口: 1. io Input and output (scipy.io) - SciPy v0.18.1 Reference Guide wavfi ...

  6. UVA 10869 - Brownie Points II(树阵)

    UVA 10869 - Brownie Points II 题目链接 题意:平面上n个点,两个人,第一个人先选一条经过点的垂直x轴的线.然后还有一个人在这条线上穿过的点选一点作垂直该直线的线,然后划分 ...

  7. WPF特效-实现3D足球效果

    原文:WPF特效-实现3D足球效果 WPF 实现 3D足球效果,效果图如下:  每个面加载不同贴图. <UserControl x:Class="MediaBalll.Model3Ds ...

  8. v-charts显示标题

    使用v-charts的时候,如果要显示标题需要以下操作 1. 加入:title props <ve-pie :title="chartTitle" :data="c ...

  9. JS顶级对象window

    <script type="text/javascript">        var num = 100;         alert(num);       wind ...

  10. 【wpf】在win10系统上弹出toast和notification

    原文:[wpf]在win10系统上弹出toast和notification 老规矩,先看效果 右下角的notification: 操作中心的notification: 整体效果: 前提条件 1.需要在 ...