3.scala容器

作者: bigdataer | 来源:发表于2017-03-14 19:40 被阅读44次

版权申明:转载请注明出处。
文章来源:http://bigdataer.net/?p=251

排版乱?请移步原文获得更好的阅读体验

3.1数组

(1) 定长数组(Array)

//直接声明使用
val array = Array("a","b","c")

//设置数组长度并赋值
val array = new Array[String](3)
array(0) = "a"
array(1) = "b"
array(2) = "c"

(2) 数组缓冲(ArrayBuffer)
数组缓冲是一种可变的数组,类似于Java中的ArrayList,但是ArrayBuffer提供了非常丰富的api

//声明
import scala.collection.multable.ArrayBuffer
val buf = new ArrayBuffer[Int]()

//添加单个元素
buf += 1

//添加多个元素
buf ++= (2,3,4)

//追加一个数组
buf ++= Array(5,6,7)

更多操作可以参考API文档

(3)数组的高级API

//数组内元素求和
Array(1,3,5).sum
//取最大值
Array(1,2,4).max
//排序
val newArray = Array(3,2,5,7,1).sortWith(_>_)

可以自定义排序方法,或者使用scala提供的排序方法,如:

val a = Array(3,2,5,7,1)
//使用快排
scala.util.Sorting.quickSort(a) //不会产生新的数组,原来数组中的元素位置改变

注意:ArrayBuffer不能排序,因为数组缓冲中的元素个数不确定。

(4)与Java互操作
java.util.List转化为scalaArrayBuffer:import scala.collection.JavaConversions.asScalaBuffer
ArrayBuffer转java List: import scala.collection.JavaConversions.bufferAsJavaList

3.2映射

scala中映射也分可变映射和不可变映射。

//创建一个不可变映射
val rank = Map("zs" -> 3,"ls" -> 4)

//创建一个可变的映射,两种方法
val rank = scala.collection.multable.Map("zs" -> 3,"ls" -> 4)
val rank  = new scala.collection.multable.Map[String,Int]()

//添加删除元素
rank +=("ww" -> 5,"zl" -> 6)
rank -= "ww"

//更新可变映射
rank("zs") = 30 

//迭代映射
for((k,v) <- map){ some code}

3.3元组

元组是一种能存放不同数据类型的容器,一般声明如下:

//声明
val tuple = (11.11,12,"bb")

//遍历
tuple.foreach{}

相关文章

  • 3.scala容器

    版权申明:转载请注明出处。文章来源:http://bigdataer.net/?p=251 排版乱?请移步原文获得...

  • 3.Scala 进一步

    本篇继续上一篇对Scala的整体介绍,本篇进一步解释Scala的一些高级特性,当你学完本篇后,就有足够的知识编写一...

  • Docker入门(3)---Docker容器

    Docker 容器操作 启动容器 启动已终止容器 容器查看 停止容器 进入容器 删除容器

  • Docker容器管理

    目录 创建容器 启动容器 停止容器 进入容器 删除容器 容器迁移 1. 创建容器 docker创建容器可以用doc...

  • Docker 容器命令

    运行容器 运行Redis容器: 容器列表 停止容器 停止Redis 启动容器 停止Redis 端口映射 删除容器 ...

  • 一、容器

    (1)容器分类 <1>顺序容器(序列容器) <2>关联容器 <3>容器适配器 (2)vector容器 <1>概念 ...

  • docker容器命令

    1、查看运行的容器 2、查看所有的容器 3、创建容器 4、进入容器 5、启动容器 6、停止容器 7、删除容器 8、...

  • spring的父子容器及配置

    spring父子容器 spring总的上下文容器有父子之分,父容器和子容器。** 父容器对子容器可见,子容器对父容...

  • STL--vector、deque、list、set、map、s

    vector(向量容器) deque(双端队列容器) list(链表容器) set(集合容器) map(映射容器)

  • docker容器基本操作

    启动交互式容器 查看容器 自定义容器的名字 重启启动停止的容器 删除停止的容器 守护式容器 什么是守护式容器: 能...

网友评论

    本文标题:3.scala容器

    本文链接:https://www.haomeiwen.com/subject/dstknttx.html