Spark记录-Scala数组
Scala提供了一种数据结构叫作数组,数组是一种存储了相同类型元素的固定大小顺序集合。数组用于存储数据集合,但将数组视为相同类型变量的集合通常更为有用。
可以声明一个数组变量,例如:numbers
,使用numbers[0]
,numbers[1]
和...
,numbers[99]
来表示单个变量,而不是分别地声明每个变量,例如number0
,number1
,...
等变量。 本教程介绍如何使用索引变量声明数组变量,创建数组和使用数组。数组的第一个元素的索引是数字0
,最后一个元素的索引是元素的总数减去1
。
声明数组变量
要在程序中使用数组,必须先声明一个变量来引用数组,并且必须指定变量可引用的数组类型。
以下是声明数组变量的语法。
语法
var z:Array[String] = new Array[String](3)
// 或者
var z = new Array[String](3)
这里,变量z
被声明为可以容纳三个元素的字符串数组。可以将值分配给单个元素或访问每个元素,访问元素通过使用如下命令来完成:
z(0) = "Zara"; z(1) = "Nuha"; z(4/2) = "Ayan"
一般来说,索引可以是产生整数的任何表达式。还有一种定义数组的方法 -
var z = Array("Maxsu", "Nancy", "Alen")
以下图片表示一个名称为:myList
的数组。 这里,myList
保存十个双精度(double
)值,索引为0
到9
。
处理处理
当处理数组元素时,我们经常使用循环控制结构,因为数组中的所有元素都是相同的类型,数组的大小是已知的。
下面是一个示例程序,演示如何创建,初始化和处理数组 -
示例
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);
}
}
将上述程序保存在源文件: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
Scala不直接支持各种数组操作,它提供各种方法来处理任何维度的数组。 如果要使用不同的方法,则需要导入Array._
包。
多维数组
在许多情况下,需要定义和使用多维数组(即数组的数组)。 例如,矩阵和表是可以被实现为二维数组结构的例子。
以下是定义二维数组的示例 -
var myMatrix = ofDim[Int](3,3)
这是一个具有三个元素的数组,每个元素都是一个具有三个元素的整数数组。
尝试以下示例程序来处理多维数组 -
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();
}
}
}
将上述程序保存在源文件:Demo.scala中,使用以下命令编译和执行此程序。
D:\>scalac Demo.scala
D:\>scala Demo
0 1 2
0 1 2
0 1 2
连接阵列
尝试使用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 )
}
}
}
将上述程序保存在源文件: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
使用范围创建数组
使用range()
方法来生成包含给定范围内增加整数序列的数组。 您可以使用final
参数作为步差来创建序列; 如果不使用final
参数,则步差将被假定为1
。
让我们举个例子来创建一个范围(10,20,2)
的数组:创建一个数组,其元素介于10
和20
之间,范围步差为2
,数组中的元素是:10
,12
,14
,16
和18
。
另一个例子:range(10,20)
。 这里的范围不同,默认情况下它假定为1
个元素。 它创建一个数组,其元素介于10
和20
之间,范围步差为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 )
}
}
}
将上述程序保存在源文件:Demo.scala中,使用以下命令编译和执行此程序。
D:\>scalac Demo.scala
D:\>scala Demo
10 12 14 16 18
10 11 12 13 14 15 16 17 18 19
Scala数组方法
以下是使用数组时可以使用的重要方法。 如上所示,必须在使用任何上述方法之前导入Array._
包。 有关可用方法的完整列表,请查看Scala的官方文档。
序号 | 方法 | 说明 |
---|---|---|
1 | def apply( x: T, xs: T* ): Array[T] |
创建一个T 对象数组,其中T 可以是:Unit ,Double ,Float ,Long ,Int ,Char ,Short ,Byte ,Boolean 。 |
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数组的更多相关文章
- Spark记录-Scala数组/List/Map/Set
import Array._ import scala.collection.mutable.Set object DataStructure { def main(args:Array[String ...
- Spark记录-Scala程序例子(函数/List/match/option/泛型/隐式转换)
object func { def main(args:Array[String]):Unit={ //函数赋值给变量时, 必须在函数后面加上空格和下划线. def sayHello(name: St ...
- Spark记录-scala快速入门
1.hello world程序 object HelloWorld { def main(args: Array[String]) { println("Hello,World!" ...
- Spark记录-Scala集合
Scala列表 Scala列表与数组非常相似,列表的所有元素都具有相同的类型,但有两个重要的区别. 首先,列表是不可变的,列表的元素不能通过赋值来更改. 其次,列表表示一个链表,而数组是平的. 具有类 ...
- Spark记录-Scala记录(基础程序例子)
import scala.util.control._ object learnning { def main(args:Array[String]):Unit={ val n:Int=10 prin ...
- Spark记录-Scala字符串
Scala字符串 在Scala中的字符串和Java中的一样,字符串是一个不可变的对象,也就是一个不能修改的对象.可以修改的对象,如数组,称为可变对象.字符串是非常有用的对象,在本节的最后部分,我们将介 ...
- Spark记录-Scala shell命令
1.scala shell命令 scala> :help All commands can be abbreviated, e.g., :he instead of :help. :edit & ...
- Spark记录-Scala语法基础
参考:http://docs.scala-lang.org/cheatsheets/index.html.http://docs.scala-lang.org/.http://www.scala-la ...
- Spark记录-Scala函数
Scala函数 Scala有函数和方法. Scala方法是一个具有名称和签名的类的一部分. Scala中的函数是一个可以分配给变量的完整对象. 函数定义可以出现在源文件中的任何位置. 不带参数的函数 ...
随机推荐
- 浅析java构造函数前的访问限定符问题
曾经一直有个问题困扰着我,我一直以为构造函数前面不能加任何东西,但偶然间看到了一本书上写的代码中,构造函数前加了public限定符,心里很是疑惑,构造函数前加毛访问限定符啊??! 在网上查了很多资料 ...
- BLCR技术初探
BLCR技术到底是什么技术?我没空和你乱扯,自己去看该官方网站的介绍:http://crd.lbl.gov/groups-depts/ftg/projects/current-projects/BLC ...
- linux下SpringBoot Jar包自启脚本配置
今天整理服务器上SpringBoot项目发现是自启的,于是想看看实现.翻看离职同事的交接文档发现一个***.service文件内容如下 [Unit] Description=sgfront After ...
- HTTP 和 HTTPS 直观上看哪里不一样了
1. 我在自己搭建的 HTTP 网站上进行登陆测试 填写账号和密码,账号:123456 ,密码:654321 (当然是乱填的,只为了看传输数据) 点击登录,用wireshark抓包看看传输的数据 2. ...
- 第一个spring冲刺总结及后诸葛亮报告(附团队贡献分)
眨眼就完结了第一阶段的冲刺了,之前因为学校停电停水等诸多原因而导致冲刺完毕时间的推迟. 第一阶段总体是做到了运算的功能,只是一些基本的功能实现,但能保证的容错性能较高. 1.在普遍的四则运算中都能见到 ...
- Java的三大特性:封装、继承、多态
一.类的概念: 类一般包括两个部分:属性(成员变量)和方法(成员方法)方法组成部分:修饰符(可选) 返回值类型(必须) 方法名(必须)参数列表(可选) package com.classTest.pr ...
- appearance格式化表单元素的边框,在chrome和FF下鼠标点击时会多出一个蓝色边框
可在元素上添加样式 -webkit-appearance: none; -moz-appearance:none;outline:none; 清除掉元素所有的外貌,以便自定义风格
- iOS国际化——通过脚本使storyboard翻译自增
一. 针对两种文件的国际化处理 代码中即.m文件的国际化 首先在你需要进行国际化处理的字符串外面加一层NSLocalizedString,注意中文也是可以的哦 textfield.text = [NS ...
- order by null 的作用
在SQL中order by null有什么用吗?这是我在一次面试时面试官问我的问题,当时我是懵的.他让我猜一下,我说不排序?没想到被我猜对了 不排序你就别用order by啊!为什么要用order b ...
- CentOS75 安装 telnet 进行使用.
1. 安装必须要的服务 yum install xinetd telnet telnet-server 2. 修改增加root用户登录权限 vi /etc/securetty 在最后面增加两行 pts ...