Scala语言之数据集合(5)

==> Scala 中的数据集合:Map、列表、序列、集

==> 集合有两种: 可变集合,不可变集合

        ---> 可变集合    可以对集合进行修改操作

        ---> 不可变集合    集合从不改变,因此可以安全的共享其引用

==> Map

        ---> 可变

val employeeInfo = scala.collection.mutable.Map("name"->"Tom", "age"->25, "gender"->"man")

        ---> 不可变

val employeeInfo = scala.collection.immutable.Map("name"->"Tom", "age"->25, "gender"->"man")

        ---> 操作

val employeeInfo = scala.collection.mutable.Map("name"->"Tom", "age"->25, "gender"->"man")

// 获取集合中的值
employeeInfo("name")        
// 若 Key 不存在,会抛出 Exception,因此,需要进行判断
if (employeeInfo.contains("girlfriend")){
    employeeInfo("girlfriend")
}else{
    -1
}

// 可以简写成
employeeInfo.getOrElse("girlfriend", -1)

// 可以修改可变集合中的值
employeeInfo("age") = 28

// 也可以添加字数
employeeInfo += "girlfriend" -> "如花"

==> 列表

        ---> 可变

import scala.collection.mutable

// 定义一个可变列表
val testList = mutable.LinkedList(1,2,3,4,5)

// 对列表进行操作: 将列表中的每个值 乘以 2
// 首先定义一个指针指向列表的开始
var cur = testList

// 使用循环操作列表,Nil 相当于 null
while(cur != Nil){
    // elem 相当于一个变量,将循环取出的值赋给此变量,乘以2
    cur.elem = cur.elem * 2
    // 将指针指向下一个元素
    cur = cur.next
}

println(testList)


        ---> 不可变

定义一个不可变列表
val testList = List(1,2,3,4)

定义一个空列表
val testList1:List[Nothing] = List()

定义一个二维列表
val testList2:List[List[Int]] = List(List(1,2,3), List(4,5,6))

判断列表是否为空
testList.isEmpty

查看列表第一个元素
testList.head

tail 返回除去第一个元素后其余的所有元素
testList.tail

==> 序列

        ---> Range(2,5)

        ---> (2 to 4)

        ---> (2 until 5)

==> 集 (set)    不重复元素的集合,不保留元素插入的顺序,默认以 Hash 集实现

        ---> 创建集以及操作

// 创建一个集
var  testSet = Set(1,3,5,9,8)

// 向集中添加元素
testSet += "hello"

// 判断元素是否存在
testSet contains(3)

// 判断一个集是否是它的子集
Set(1,3) subsetOf(testSet)

        ---> 集的运算(并集、交集、差集)

var testset1 = Set(1,2,3,4,5,6)
var testset2 = Set(4,5,6,7,8,9)
// 并集
testset1 union testset2
res8: scala.collection.immutable.Set[Int] = Set(5, 1, 6, 9, 2, 7, 3, 8, 4)

// 交集
testset1 intersect testset2
res10: scala.collection.immutable.Set[Int] = Set(5, 6, 4)

// 差集
testset1 diff testset2
res11: scala.collection.immutable.Set[Int] = Set(1, 2, 3)

原文地址:http://blog.51cto.com/songqinglong/2072039

时间: 2024-10-07 06:54:59

Scala语言之数据集合(5)的相关文章

Spark 大数据中文分词统计(三) Scala语言实现分词统计

Java版的Spark大数据中文分词统计程序完成之后,又经过一周的努力,把Scala版的Spark 大数据中文分词统计程序也搞出来了,在此分享给各位想学习Spark的朋友. 如下是程序最终运行的界面截图,和Java版差别不大: 如下是Scala工程结构: 当你在工程主类文件WordCounter.scala上单击右键,选择Run As Scala Application: 然后选择唐诗宋词进行分词统计,就会出现前面显示的分词结果. 工程代码已经上传CSDN:http://download.csd

大数据学习之Scala语言基本语法学习36

一:scala简介 官网:https://www.scala-lang.org/ Scala语言很强大,集成了面向对象和函数式编程的特点. 运行在JVM(jdk). 大数据中为什么学习scala? spark是scala语言编写. python写spark 挺好的 java写spark 很糟糕(代码实在是太多了) scala写spark 很完美 二:scala特点 1)优雅 框架设计中第一个要考虑的问题就是API是否优雅. 精简的封装. 代码精简(少). 2)速度快 scala语言表达能力强.

Spark GraphX宝刀出鞘,图文并茂研习图计算秘笈与熟练的掌握Scala语言【大数据Spark

Spark GraphX宝刀出鞘,图文并茂研习图计算秘笈 大数据的概念与应用,正随着智能手机.平板电脑的快速流行而日渐普及,大数据中图的并行化处理一直是一个非常热门的话题.图计算正在被广泛地应用于社交网络.电子商务,地图等领域.对于图计算的两个核心问题:图存储模式和图计算模型,Spark GraphX给出了近乎完美的答案, 而Spark GraphX作为图计算领域的屠龙宝刀,对Pregel  API的支持更是让Spark GraphX如虎添翼.Spark GraphX可以轻而易举的完成基于度分布

大数据spark学习第一周Scala语言基础

Scala简单介绍 Scala(Scala Language的简称)语言是一种能够执行于JVM和.Net平台之上的通用编程语言.既可用于大规模应用程序开发,也可用于脚本编程,它由由Martin Odersk于2001开发.2004年開始程序执行在JVM与.Net平台之上.由于其简洁.优雅.类型安全的编程模式而受到关注. Scala的创建者——Martin Odersk 在Scala的创建之初,并没有怎么引起重视,随着Apache Spark和Apache Kafka这样基于Scala的大数据框架

Spark使用Scala语言进行实现,它是一种面向对象

Spark是加州大学伯克利分校AMP实验室(Algorithms, Machines, and People Lab)开发通用内存并行计算框架.Spark在2013年6月进入Apache成为孵化项目,8个月后成为Apache顶级项目,速度之快足见过人之处,Spark以其先进的设计理念,迅速成为社区的热门项目,围绕着Spark推出了Spark SQL.Spark Streaming.MLLib和GraphX等组件,也就是BDAS(伯克利数据分析栈),这些组件逐渐形成大数据处理一站式解决平台.从各方

新书:Scala语言基础与开发实战

大数据科学丛书系列的最新一本<Scala语言基础与开发实战>即将面市,预计月底上架.内容还是不错的,文笔简介,内容实用,值得学.用. 大数据资深培训师王家林新作. 详细介绍大数据开发语言Scala及其在分布式框架Akka和Kafka中的应用. 秉承"实战"类图书特点,解析大量代码的编写操作,具有较强的可操作性,便于读者学习和理解. 算上再过几个月出版的<Spark内核解析及性能调优>,一年时间,大数据科学丛书系列之Spark的小套系基本形成了:从学习Spark的

初解,Scala语言中基于Actor的并发编程的机制,并展示了在Spark中基于Scala语言的Actor而产生的消息驱动框架Akka的使用,

Scala深入浅出实战中级--进阶经典(第66讲:Scala并发编程实战初体验及其在Spark源码中应用解析)内容介绍和视频链接 2015-07-24 DT大数据梦工厂 从明天起,做一个勤奋的人 看视频.下视频,分享视频 DT大数据梦工厂-Scala深入浅出实战中级--进阶经典:第66讲:Scala并发编程实战初体验及其在Spark源码中的应用解析 本期视频通过代码实战详解了Java语言基于加锁的并发编程模型的弊端以及Scala语言中基于Actor的并发编程的机制,并展示了在Spark中基于Sc

Scala语言初识

scala是一种集面向对象特性和函数式特性于一身并可运行在JVM上的强类型静态语言.因为可以运行在JVM上,并在设计时借鉴于大量的java语言特性,故可以和java互动并可以调用java相关类库,这让现在大量掌握java的编程者的智力投资得到极大的利用.并且还借鉴了Elang函数语言及Ruby等脚本语言,从而有高效,轻便等特性,从而原来掌握Ruby,Erlang等语言者,来学习scala时感到亲切从而更加快捷掌握. scala由洛桑联邦理工学院的Martin Odersky设计,第一个版本发布于

华为C语言笔试题集合

①华为笔试题搜集 1.static有什么用途?(请至少说明两种)    1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变.    2) 在模块内(但在函数体外),一个被声明为静态的变量能够被模块内所用函数訪问,但不能被模块外其他函数訪问.它是一个本地的全局变量.    3) 在模块内,一个被声明为静态的函数仅仅可被这一模块内的其他函数调用.那就是,这个函数被限制在声明它的模块的本地范围内使用 2.引用与指针有什么差别?    1) 引用必须被初始化,指针不必.    2)