一、数组

  • 在Scala中,用()来访问元素,数组声明的语法格式如下 :
var z:Array[String] = new Array[String](3)

var z = new Array[String](3)
  • 类型参数化数组

Scala里用new实例化对象,实例过程中,可以用值和类型使对象参数化(在创建实例的同时完成对它的“设置”)。

scala> val greetString =new Array[String](3)
greetString: Array[String] = Array(null, null, null) scala> greetString(0)="Hello"
scala> greetString(1)=","
scala> greetString(2)="world!"
scala> for(i<-0 to 2) print(greetString(i))
Hello,world!
scala>

  注:由上可知数组greetString(0)是数组的首个元素,且i<-0 to 2即为(0).to(2)

  • 数组缓存

ArrayBuffer与数组类似,保留了所有的Array操作,还允许在序列的开始或结束的地方添加和删除元素。

//先从可变集合包中引用
scala> import scala.collection.mutable.ArrayBufferimport scala.collection.mutable.ArrayBuffer //必须指定ArrayBuffer参数类型,可以不指定长度,可自动调整分配空间
scala> val buf=new ArrayBuffer[Int]()
buf: scala.collection.mutable.ArrayBuffer[Int] = ArrayBuffer() //使用+=添加元素
scala> buf +=12
res19: buf.type = ArrayBuffer(12)
scala> buf +=15
res20: buf.type = ArrayBuffer(12, 15)
scala> buf
res21: scala.collection.mutable.ArrayBuffer[Int] = ArrayBuffer(12, 15) //缓存可用数组能用的方法
scala> buf.length
res22: Int = 2
scala> buf(0)
res23: Int = 12

  

二、列表list

列表是同质的,列表中的所有元素都具有相同的类型。元素类型为T的列表类型写作List[T]

  • Scala的列表类(List)创建方法如下:
scala> val oneTwoThree=List(1,2,3)//创建并初始化
oneTwoThree: List[Int] = List(1, 2, 3)
  • 列表类中定义了“:::”方法实现叠加,用法如下:
scala> val oneTwoThree=List(1,2,3)
oneTwoThree: List[Int] = List(1, 2, 3)
scala> val four=List(4)
four: List[Int] = List(4) scala> val ottf=oneTwoThree:::four
ottf: List[Int] = List(1, 2, 3, 4)
  • 列表类中最常用的操作符是“::”,它可以把新元素组合到现有列表的最前端,然后返回作为执行结果的新列表。
scala> val oneTwoThree=List(1,2,3)
oneTwoThree: List[Int] = List(1, 2, 3) scala> val oneTwoThreefour=4::oneTwoThree
oneTwoThreefour: List[Int] = List(4, 1, 2, 3)
  • Nil是空列表的简写,::是定义在List类上的方法1,2,3是Int类型,
scala> val oneTwoThreefour=1::2::3::4
<console>:11: error: value :: is not a member of Int
val oneTwoThreefour=1::2::3::4
^ scala> val oneTwoThreefour=1::2::3::4::Nil
oneTwoThreefour: List[Int] = List(1, 2, 3, 4) scala>
  • Scala里的列表类型是协变的。这意味着对于每一对类型,S是T的子类型,那么List[S]是List[T] 的子类型。

    //List()同样是List[String]的
    val xs:List[Sreing]=List() 
  • 构造列表,所有的列表都是由两个基础的构造块Nil和::构造出来的。
  • 列表的基本操作:head(返回列表的第一个元素)、tail(返回列表的第一个之外的所有元素)、isEmpty(判断是否为空,返回true)
scala> Nil.head//head和tail都仅能作用在非空列表上,否则抛出异常
java.util.NoSuchElementException: head of empty list
at scala.collection.immutable.Nil$.head(List.scala:430)
... 28 elided
  • 连接列表,连接操作是“:::”,它的两个操作元是列表,且是右结合
scala> List(1,2):::(List(3,4,5):::List(9,8,7))
res12: List[Int] = List(1, 2, 3, 4, 5, 9, 8, 7)
scala> List(1,2):::List(3,4,5):::List(9,8,7)
res13: List[Int] = List(1, 2, 3, 4, 5, 9, 8, 7)
  • 列表缓存
//先从可变集合包中引用
scala> import scala.collection.mutable.ListBuffer
import scala.collection.mutable.ListBuffer
//实例化
scala> val buf=new ListBuffer[Int]
buf: scala.collection.mutable.ListBuffer[Int] = ListBuffer()
//+=添加元素
scala> buf +=11
res24: buf.type = ListBuffer(11)
scala> buf +=12
res25: buf.type = ListBuffer(11, 12)
scala> buf
res26: scala.collection.mutable.ListBuffer[Int] = ListBuffer(11, 12)
scala> 3+:buf
res27: scala.collection.mutable.ListBuffer[Int] = ListBuffer(3, 11, 12) scala> buf.toList
res28: List[Int] = List(11, 12)
scala> buf
res29: scala.collection.mutable.ListBuffer[Int] = ListBuffer(11, 12) scala> 3 +: buf
res30: scala.collection.mutable.ListBuffer[Int] = ListBuffer(3, 11, 12)
scala> buf
res31: scala.collection.mutable.ListBuffer[Int] = ListBuffer(11, 12)
//出现问题,toList没有显示出3
scala> buf.toList
res32: List[Int] = List(11, 12)

  出现问题,toList没有显示出3

三、元组

  • 元组可以包含不同类型的元素,但是和列表一样不可变,把元组实例化需要的对象放在括号里,元组实例化后可以用点号、下划线和基于1的索引访问其他元素,如下:
scala> val pair=(99,"Luft")
pair: (Int, String) = (99,Luft)
scala> println(pair._1)
99
scala> println(pair._2)
Luft

 注:元组的实际类型取决于它含有的元素数量和这些元素的类型。故(11,25,s,ss)的类型是
Tupa: (Int, Int, Char, String)

四、集set和映射map

对于set和map来说,Scala同样有可变和不可变的,不过不是阁提供两种选择,而是通过类继承的差别把可变性差异蕴含其中。其中Scala的API包含了set的基本特质,Scala还提供了两个子特质,分别为可变和不可变set。(Java是实现接口,Scala是“扩展”/“混入”了特质。)其中,在Scala中,set和map的层级如下:

  • 创建初始化和使用不可变集
scala> var jetSet =Set("Beoing","Airbus")
jetSet: scala.collection.immutable.Set[String] = Set(Beoing, Airbus) scala> jetSet +="Lear" scala> println(jetSet.contains("Cessna"))
false scala> jetSet
res41: scala.collection.immutable.Set[String] = Set(Beoing, Airbus, Lear)
  • 创建初始化和使用可变集
//没有引入包
scala> val movieSet = Set("Hitch","Poltergeist")
movieSet: scala.collection.immutable.Set[String] = Set(Hitch, Poltergeist) scala> movieSet += "Shrek"
<console>:13: error: value += is not a member of scala.collection.immutable.Set[String]
Expression does not convert to assignment because receiver is not assignable.
movieSet += "Shrek"
//和上面的不可变集的前两步相同,
//主要是分别用val和var的区别

 

//引入包
scala> import scala.collection.mutable.Set
import scala.collection.mutable.Set
scala> val movieSet = Set("Hitch","Poltergeist")
movieSet: scala.collection.mutable.Set[String] = Set(Poltergeist, Hitch)
scala> movieSet += "Shrek"
res48: movieSet.type = Set(Poltergeist, Shrek, Hitch)
scala> println(movieSet)
Set(Poltergeist, Shrek, Hitch)

  

  • 不可变的map是默认的,不用引用其他类,创建、初始化和使用不可变映射
scala> val romanNumral = Map(
| 1->"I",2->"II",3->"III",4->"IV",5->"V"
| )
romanNumral: scala.collection.immutable.Map[Int,String] = Map(5 -> V, 1 -> I, 2 -> II, 3 -> III, 4 -> IV) scala> println(romanNumral(4))
IV
  • 创建、初始化和使用可变映射
scala> import scala.collection.mutable.Map
import scala.collection.mutable.Map scala> val treasureMap=Map[Int,String]()
treasureMap: scala.collection.mutable.Map[Int,String] = Map()
scala> treasureMap+=(1->"Good")
res44: treasureMap.type = Map(1 -> Good)
scala> treasureMap+=(2->"kid")
res45: treasureMap.type = Map(2 -> kid, 1 -> Good)
scala> treasureMap+=(3->"!")
res46: treasureMap.type = Map(2 -> kid, 1 -> Good, 3 -> !)
scala> println(treasureMap(2))
kid

  没有导入包的测试如下:

scala> val treasureMap=Map[Int,String]()
treasureMap: scala.collection.immutable.Map[Int,String] = Map() scala> treasureMap+=(1->"Good")
<console>:13: error: value += is not a member of scala.collection.immutable.Map[Int,String]
Expression does not convert to assignment because receiver is not assignable.
treasureMap+=(1->"Good")

  注:var和val的声明,和mutable和immuatble之间的联系

Scala实践4的更多相关文章

  1. Scala实践14

    1.Scala的future 创建future import scala.concurrent._ import ExecutionContext.Implicits.global object Fu ...

  2. Scala实践13

    1.隐式参数 方法可以具有隐式参数列表,由参数列表开头的implicit关键字标记.如果该参数列表中的参数没有像往常一样传递,Scala将查看它是否可以获得正确类型的隐式值,如果可以,则自动传递. S ...

  3. Scala实践12

    1.内部类和抽象类型成员作为对象成员 内部类 在Scala中,可以让类将其他类作为成员.这些内部类是封闭类的成员.在Scala中,这样的内部类绑定到外部对象.假设希望编译器在编译时阻止我们混合哪些节点 ...

  4. Scala实践11

    1.1泛型类 泛型类是将类型作为参数的类.它们对集合类特别有用. 定义泛类型:泛型类将类型作为方括号内的参数[].一种惯例是使用字母A作为类型参数标识符,但是可以使用任何参数名称. class Sta ...

  5. Scala实践10

    1.模式匹配 模式匹配是一种根据模式检查值的机制.它是switch(Java中语句)的更强大版本,它同样可以用来代替一系列if / else语句. 句法 匹配表达式具有值,match关键字和至少一个c ...

  6. Scala实践9

    1.特征 Traits用于在类之间共享接口和字段.它们类似于Java 8的接口.类和对象可以扩展特征,但是特征不能被实例化,因此没有参数. 定义一个特征 最小特征只是关键字trait和标识符: tra ...

  7. Scala实践6

    1  if表达式 Scala中if...else..表达式是有返回值的,如果if和else返回值类型不一样,则返回Any类型. scala> val a3=10 a3: Int = 10 sca ...

  8. Scala实践8

    1.1继承类 使用extends关键字,在定义中给出子类需要而超类没有的字段和方法,或者重写超类的方法. class Person { var name = "zhangsan" ...

  9. Scala实践7

    一.类 1.1简单类和无参方法 类的定义通过class关键字实现 scala> class Dog { | private var leg = 4 | def shout(content: St ...

  10. Scala实践5

    一.Scala的层级 1.1类层级 Scala中,Any是所其他类的超类,在底端定义了一些有趣的类NULL和Nothing,是所有其他类的子类. 根类Any有两个子类:AnyVal和AnyRef.其中 ...

随机推荐

  1. 洛谷P2590 [ZJOI2008]树的统计 题解 树链剖分+线段树

    题目链接:https://www.luogu.org/problem/P2590 树链剖分模板题. 剖分过程要用到如下7个值: fa[u]:u的父节点编号: dep[u]:u的深度: size[u]: ...

  2. mysql 第一课 win7艰难的配置与删除注册表重新安装

    mysql 这个安装一定要慎重!慎重!慎重! 重要的事情说三遍.. 不会的一定要按步骤来~出错了真的很难受. 详细教程 -->  https://jingyan.baidu.com/album/ ...

  3. P1094 百钱白鸡

    题目描述 公鸡5文钱一只,母鸡3文钱一只,小鸡3只一文钱,用100文钱买100只鸡,其中公鸡,母鸡,小鸡都必须要有,问公鸡,母鸡,小鸡要买多少只刚好凑足100文钱. 输入格式 无. 输出格式 输出所有 ...

  4. 【9101】求n!的值

    Time Limit: 10 second Memory Limit: 2 MB 问题描述 用高精度的方法,求n!的精确值(n的值以一般整数输入). Input 文件输入仅一行,输入n. Output ...

  5. 【js】vue 2.5.1 源码学习 (十一) 模板编译compileToFunctions渲染函数

    大体思路(九) 本节内容: 1. compileToFunctions定位 1. compileToFunctions定位 ==> createCompiler = createCompiler ...

  6. The Function() Constructor

    Functions are usually defined using the function keyword, either in the form of a function definitio ...

  7. HDU 1540 Tunnel Warfare (线段树)

    Tunnel Warfare Problem Description During the War of Resistance Against Japan, tunnel warfare was ca ...

  8. H3C使用tracert命令--用户视图

    <H3C>tracert ?                                                                     -a       指明 ...

  9. Linux 内核 ksets 之上的操作

    对于初始化和设置, ksets 有一个接口非常类似于 kobjects. 下列函数存在: void kset_init(struct kset *kset); int kset_add(struct ...

  10. 2019牛客多校第一场 I Points Division(动态规划+线段树)

    2019牛客多校第一场 I Points Division(动态规划+线段树) 传送门:https://ac.nowcoder.com/acm/contest/881/I 题意: 给你n个点,每个点有 ...