Scala提供了一种数据结构叫作数组,数组是一种存储了相同类型元素的固定大小顺序集合。数组用于存储数据集合,但将数组视为相同类型变量的集合通常更为有用。

可以声明一个数组变量,例如:numbers,使用numbers[0]numbers[1]...numbers[99]来表示单个变量,而不是分别地声明每个变量,例如number0number1...等变量。 本教程介绍如何使用索引变量声明数组变量,创建数组和使用数组。数组的第一个元素的索引是数字0,最后一个元素的索引是元素的总数减去1

声明数组变量

要在程序中使用数组,必须先声明一个变量来引用数组,并且必须指定变量可引用的数组类型。

以下是声明数组变量的语法。

语法

var z:Array[String] = new Array[String](3)

// 或者

var z = new Array[String](3)
Scala

这里,变量z被声明为可以容纳三个元素的字符串数组。可以将值分配给单个元素或访问每个元素,访问元素通过使用如下命令来完成:

z(0) = "Zara"; z(1) = "Nuha"; z(4/2) = "Ayan"
Scala

一般来说,索引可以是产生整数的任何表达式。还有一种定义数组的方法 -

var z = Array("Maxsu", "Nancy", "Alen")
Scala

以下图片表示一个名称为:myList的数组。 这里,myList保存十个双精度(double)值,索引为09

处理处理

当处理数组元素时,我们经常使用循环控制结构,因为数组中的所有元素都是相同的类型,数组的大小是已知的。

下面是一个示例程序,演示如何创建,初始化和处理数组 -

示例

object Demo {
def main(args: Array[String]) {
var myList = Array(1.9, 2.9, 3.4, 3.5) // Print all the array elements
for ( x <- myList ) {
println( x )
} // Summing all elements
var total = 0.0; for ( i <- 0 to (myList.length - 1)) {
total += myList(i);
}
println("Total is " + total); // Finding the largest element
var max = myList(0); for ( i <- 1 to (myList.length - 1) ) {
if (myList(i) > max) max = myList(i);
} println("Max is " + max);
}
}
Scala

将上述程序保存在源文件:Demo.scala中,使用以下命令编译和执行此程序。

D:\>scalac Demo.scala
D:\>scala Demo 1.9
2.9
3.4
3.5
Total is 11.7
Max is 3.5
Shell

Scala不直接支持各种数组操作,它提供各种方法来处理任何维度的数组。 如果要使用不同的方法,则需要导入Array._包。

多维数组

在许多情况下,需要定义和使用多维数组(即数组的数组)。 例如,矩阵和表是可以被实现为二维数组结构的例子。

以下是定义二维数组的示例 -

var myMatrix = ofDim[Int](3,3)
Scala

这是一个具有三个元素的数组,每个元素都是一个具有三个元素的整数数组。

尝试以下示例程序来处理多维数组 -

import Array._

object Demo {
def main(args: Array[String]) {
var myMatrix = ofDim[Int](3,3) // build a matrix
for (i <- 0 to 2) {
for ( j <- 0 to 2) {
myMatrix(i)(j) = j;
}
} // Print two dimensional array
for (i <- 0 to 2) {
for ( j <- 0 to 2) {
print(" " + myMatrix(i)(j));
}
println();
}
}
}
Scala

将上述程序保存在源文件:Demo.scala中,使用以下命令编译和执行此程序。

D:\>scalac Demo.scala
D:\>scala Demo 0 1 2
0 1 2
0 1 2
Shell

连接阵列

尝试使用concat()方法连接两个数组的以下示例。可以将多个数组作为参数传递给concat()方法。

import Array._

object Demo {
def main(args: Array[String]) {
var myList1 = Array(1.9, 2.9, 3.4, 3.5)
var myList2 = Array(8.9, 7.9, 0.4, 1.5) var myList3 = concat( myList1, myList2) // Print all the array elements
for ( x <- myList3 ) {
println( x )
}
}
}
Scala

将上述程序保存在源文件:Demo.scala中,使用以下命令编译和执行此程序。

D:\>scalac Demo.scala
D:\>scala Demo 1.9
2.9
3.4
3.5
8.9
7.9
0.4
1.5
Shell

使用范围创建数组

使用range()方法来生成包含给定范围内增加整数序列的数组。 您可以使用final参数作为步差来创建序列; 如果不使用final参数,则步差将被假定为1

让我们举个例子来创建一个范围(10,20,2)的数组:创建一个数组,其元素介于1020之间,范围步差为2,数组中的元素是:10,12,14,1618

另一个例子:range(10,20)。 这里的范围不同,默认情况下它假定为1个元素。 它创建一个数组,其元素介于1020之间,范围步差为1。数组中的元素为:10,11,12,13...19

以下示例程序显示如何使用范围创建数组。

示例

import Array._

object Demo {
def main(args: Array[String]) {
var myList1 = range(10, 20, 2)
var myList2 = range(10,20) // Print all the array elements
for ( x <- myList1 ) {
print( " " + x )
} println()
for ( x <- myList2 ) {
print( " " + x )
}
}
}
Scala

将上述程序保存在源文件:Demo.scala中,使用以下命令编译和执行此程序。

D:\>scalac Demo.scala
D:\>scala Demo 10 12 14 16 18
10 11 12 13 14 15 16 17 18 19
Shell

Scala数组方法

以下是使用数组时可以使用的重要方法。 如上所示,必须在使用任何上述方法之前导入Array._包。 有关可用方法的完整列表,请查看Scala的官方文档。

序号 方法 说明
1 def apply( x: T, xs: T* ): Array[T] 创建一个T对象数组,其中T可以是:UnitDoubleFloatLongIntCharShortByteBoolean
2 def concat[T]( xss: Array[T]* ): Array[T] 将所有数组连接成一个数组。
3 def copy( src: AnyRef, srcPos: Int, dest: AnyRef, destPos: Int, length: Int ): Unit 将一个数组复制到另一个。 相当于Java的System.arraycopy(src,srcPos,dest,destPos,length)
4 def empty[T]: Array[T] 返回长度为0的数组
5 def iterate[T]( start: T, len: Int )( f: (T) => T ): Array[T] 返回一个包含函数的重复应用程序到一个起始值的数组。
6 def fill[T]( n: Int )(elem: => T): Array[T] 返回一个包含某些元素计算结果的数组。
7 def fill[T]( n1: Int, n2: Int )( elem: => T ): Array[Array[T]] 返回一个包含一些元素计算结果的二维数组。
8 def iterate[T]( start: T, len: Int)( f: (T) => T ): Array[T] 返回一个包含一个函数的重复应用程序到一个起始值的数组。
9 def ofDim[T]( n1: Int ): Array[T] 创建具有给定维度的数组。
10 def ofDim[T]( n1: Int, n2: Int ): Array[Array[T]] 创建一个二维数组
11 def ofDim[T]( n1: Int, n2: Int, n3: Int ): Array[Array[Array[T]]] 创建一个3维数组
12 def range( start: Int, end: Int, step: Int ): Array[Int] 返回一个整数间隔中包含相等间隔值的数组。
13 def range( start: Int, end: Int ): Array[Int] 返回一个包含一个范围内增加整数序列的数组。
14 def tabulate[T]( n: Int )(f: (Int)=> T): Array[T] 0开始的整数值范围内,返回一个包含给定函数值的数组。
15 def tabulate[T]( n1: Int, n2: Int )( f: (Int, Int ) => T): Array[Array[T]]

Spark记录-Scala数组的更多相关文章

  1. Spark记录-Scala数组/List/Map/Set

    import Array._ import scala.collection.mutable.Set object DataStructure { def main(args:Array[String ...

  2. Spark记录-Scala程序例子(函数/List/match/option/泛型/隐式转换)

    object func { def main(args:Array[String]):Unit={ //函数赋值给变量时, 必须在函数后面加上空格和下划线. def sayHello(name: St ...

  3. Spark记录-scala快速入门

    1.hello world程序 object HelloWorld { def main(args: Array[String]) { println("Hello,World!" ...

  4. Spark记录-Scala集合

    Scala列表 Scala列表与数组非常相似,列表的所有元素都具有相同的类型,但有两个重要的区别. 首先,列表是不可变的,列表的元素不能通过赋值来更改. 其次,列表表示一个链表,而数组是平的. 具有类 ...

  5. Spark记录-Scala记录(基础程序例子)

    import scala.util.control._ object learnning { def main(args:Array[String]):Unit={ val n:Int=10 prin ...

  6. Spark记录-Scala字符串

    Scala字符串 在Scala中的字符串和Java中的一样,字符串是一个不可变的对象,也就是一个不能修改的对象.可以修改的对象,如数组,称为可变对象.字符串是非常有用的对象,在本节的最后部分,我们将介 ...

  7. Spark记录-Scala shell命令

    1.scala shell命令 scala> :help All commands can be abbreviated, e.g., :he instead of :help. :edit & ...

  8. Spark记录-Scala语法基础

    参考:http://docs.scala-lang.org/cheatsheets/index.html.http://docs.scala-lang.org/.http://www.scala-la ...

  9. Spark记录-Scala函数

    Scala函数 Scala有函数和方法. Scala方法是一个具有名称和签名的类的一部分. Scala中的函数是一个可以分配给变量的完整对象. 函数定义可以出现在源文件中的任何位置. 不带参数的函数 ...

随机推荐

  1. 再探Redux Middleware

    前言 在初步了解Redux中间件演变过程之后,继续研究Redux如何将中间件结合.上次将中间件与redux硬结合在一起确实有些难看,现在就一起看看Redux如何加持中间件. 中间件执行过程 希望借助图 ...

  2. 深度学习目标检测综述推荐之 Xiaogang Wang ISBA 2015

    一.INTRODUCTION部分 (1)先根据时间轴讲了历史 (2)常见的基础模型 (3)讲了深度学习的优势 那就是feature learning,而不用人工划分的feature engineeri ...

  3. NO.3:自学tensorflow之路------MNIST识别,神经网络拓展

    引言 最近自学GRU神经网络,感觉真的不简单.为了能够快速跑完程序,给我的渣渣笔记本(GT650M)也安装了一个GPU版的tensorflow.顺便也更新了版本到了tensorflow-gpu 1.7 ...

  4. java向上转型和向下转型

    转型是在继承的基础上而言的,继承是面向对象语言中,代码复用的一种机制,通过继承,子类可以复用父类的功能,如果父类不能满足当前子类的需求,则子类可以重写父类中的方法来加以扩展. 向上转型:子类引用的对象 ...

  5. 11th 最后的致意

    “终于我们不再是师生”,无论日后我们是否是师生,但这段经历是不可否认的,可以说软件工程这一门课程恐怕是我学生生涯中终生难忘的一段体验.即便不是从知识上,从另一个方面来讲,也教给了我一种做人做事的态度. ...

  6. Access restriction: The type 'BASE64Decoder' is not API

    Access restriction: The type 'BASE64Decoder' is not API (restriction on required library 'C:\Program ...

  7. [转帖]Mysql 最简单的参数调优配置

    http://blog.jobbole.com/113659/ 我并不期望成为一个专家级的 DBA,但是,在我优化 MySQL 时,我推崇 80/20 原则,明确说就是通过简单的调整一些配置,你可以压 ...

  8. 从苦逼到牛逼,详解Linux运维工程师的打怪升级之路

    做运维也快四年多了,就像游戏打怪升级,升级后知识体系和运维体系也相对变化挺大,学习了很多新的知识点. 运维工程师是从一个呆逼进化为苦逼再成长为牛逼的过程,前提在于你要能忍能干能拼,还要具有敏锐的嗅觉感 ...

  9. Jquery 临时

    <!--微信小程序--> <div id="page1" class="page page1"> <nav> <div ...

  10. nodejs nodemailer 使用

    index.js const nodemailer=require("nodemailer") let sendEmail=function () { var transporte ...