1. 元组

  映射是K/V对偶的集合,对偶是元组的最简单的形式,元组可以装着多个不同类型的值

1.1 特点

  元组相当于一个特殊的数组,其长度和内容都可变,并且数组中可以装任何类型的数据,其主要用处就是存一些类型不同的数据,如定义一个方法,其要返回多个类型不同的值,如果在java中就需要定义一个bean去set这些值并返回,而scala就方便了,直接将不同类型的数据放入元组返回。

1.2 创建元组

  定义元组时用小括号将多个元素包起来,元素之间用逗号分隔,元素的类型可以不一样,元素的个数可以任意多个,如

object TupleDemo {
def main(args: Array[String]): Unit = {
val tuple: (Int, Double, String) = m(1, 2.5)
} def m(x: Int, y: Double) = {
val x1 = x*10
val y1 = y*100
val w1 = "hello"
(x1, y1, w1)
}
}

此处涉及的快捷键:当定义元组时(m(1, 2.5)),这个时候在后面写上.var,回车即可得到变量,此时会出如下选择框(看是否给元组加类型),如下:

 alt+t即可选中Specify type(给元组加上类型),变量等定义也是一样的,当元组已经定义完了,并且没有加上数据类型,但后面又想加上,此时的快捷键为alt+enter

 

1.3 获取元组中的值

获取元组中的元素可以使用下划线加角标,但是需要注意的是元组中的元素角标是从1开始的,此外还可以自己将元组中的元素赋值给某个数(如下,a,b分别代表feng,1314)

 1.4 将对偶的集合(元组不行)转换成映射

 1.5  拉链操作

zip命令可以将多个值绑定在一起

注意:如果两个数组的元素个数不一致,拉链操作后生成的数组的长度为较小的那个数组的元素个数

2. 类、对象、继承、特质

2.1 类

  Scala的类与java类比起来更加简单,与python中类似

2.1.1类的定义

  在scala中,类并不用声明为public,默认就是public,并且在一个Scala源文件中可以包含多个类,所有这些类都具有公有可见性

class Student {
//用val修饰的变量是只读属性,有getter但没有setter
//(相当与Java中用final修饰的变量)
val id = 666
//用var修饰的变量既有getter又有setter,下划线代表对应类型的默认值,必须指定变量的类型
var age: Int = _
//类私有字段,只能在类的内部使用,和伴生对象中使用
private var name: String = "tom"
//对象私有字段,访问权限更加严格的,只能在类的内部【当前实例中使用】
private[this] val pet = "小强" }
//private 和 private[this]同样可以修饰方法
//类和伴生对象中的属性和方法都可以用访问权限控制符修饰
//类和伴生对象可以相互访问private修饰的变量和方法
//private[this]如果在类中定义,就只能在类的内容使用
//private[this]如果在object中定义,就只能在object的内容使用

2.1.2 构造器

(1)主构造器  

每个类都有主构造器,主构造器的参数直接放置在类名后面,与类交织在一起,主构造器会执行类中定义的所有语句(new构造器所在的类即会执行)

案例

//主构造器
class Person(var name: String, var age: Int) {
println("执行主构造器")
println(name+","+age)
print("主构造器执行完")
} object Person {
def main(args: Array[String]): Unit = {
val person: Person = new Person("隔壁老王",38)
}
}

执行结果

可见,在伴生对象中,new完Person对象后,Person类中的代码就被执行了

(2)辅助构造器

  • 辅助构造器是对主构造器的补充和扩展,辅助构造器的第一行一定要调用主构造器或者是其他已经调用了主构造器的辅助构造器
//主构造器
class People(val name: String) {
var age: Int = _
var gender: String = _
//辅助构造器,是对主构造器的补充和扩展
def this(name: String, age: Int) {
//辅助构造器的第一行一定要调用主构造器
this(name)
this.age = age
}
def this(name: String, age: Int, gender: String) {
//辅助构造器的第一行一定要调用主构造器,或者是其他的辅助构造器
//this(name)
this(name, age)
this.gender = gender
}
}

注意:由于辅助构造器是对主构造器的扩展,所以主构造器的参数一般比辅助构造器的参数少

  • 如果定义主构造器,参数没有用var或val修饰,那么就不会成为这个类的成员变量======>局部变量(见零基础学习java  day07)

(3)构造器的私有化

  在类名后加private就变成了私有的构造器,其只能在其伴生对象中使用

 2.2 对象

2.2.1 单例对象(可参考零基础学习java day08)

  在scala中,小写的object代表的是一个静态对象,也是单例对象,当满足一定条件时(和某个类名相同,就是该类的伴生对象)就是伴生对象

运行结果

可见,s1和s2是同一个实例

2.2.2 伴生对象

在Scala的类中,与类名相同并且被object修饰的对象叫做伴生对象,类和伴生对象之间可以相互访问私有的方法和属性

 2.2.3 Apply方法

通常我们会在类的伴生对象中定义apply方法,当遇上伴生对象(参数1.....参数n)    时,apply方法会被调用

object ApplyDemo {
def apply(): Unit = {
println(888)
} def apply(x: Int): Unit = {
println(x)
} def apply(x: Int, y: Double): Unit = {
println(x + y)
} def main(args: Array[String]): Unit = {
//静态对象名后面跟(),就是调用对应的apply方法
//ApplyDemo()
//ApplyDemo.apply() ApplyDemo(666) ApplyDemo(6, 7.5)
ApplyDemo.apply(6, 7.5) val arr = Array(1, 2, 3, 4, 5)
}
}

伴生对象() ==伴生对象.apply()

2.3 继承

  • Scala中继承使用extends,实现接口使用with
  • 在scala中,第一次不论是继承还是实现特质,都使用extends关键字,并且extends只能用一次

多态的两个前提:父类引用指向子类;重写相应的方法

3 函数

  在Scala中,方法就是方法(method),函数就是函数(function),函数本质上是一个引用

(1) 函数的定义形式

一定要调用这个函数,否则不会执行,此处的f(2)相当于f.apply(2)

(2)函数的完整定义(加上函数的类型)

 (3)匿名函数

scala中的匿名函数即不需要引用,以下便是一个匿名函数

(4)单词统计例子

  • 求集合中的偶数

第一种方法(非函数式编程):

第二种方法(函数式编程)

  首先定义一个函数,在将这个函数作为参数传入Scala自带的高级函数(此处是filter)中,即可得到结果

  • 统计集合中单词的个数(即line中单词的个数)

a.  首先需要将单词切割,得到如下结果

更加简洁的写法

 b 进行统计单词的个数

可以将上面4不组合成一步,就可以一行代码解决问题

在IDEA上写词案例:

大数据学习day14-----第三阶段-----scala02------1. 元组 2.类、对象、继承、特质 3.函数(必须掌握)的更多相关文章

  1. 大数据学习--day14(String--StringBuffer--StringBuilder 源码分析、性能比较)

    String--StringBuffer--StringBuilder 源码分析.性能比较 站在优秀博客的肩上看问题:https://www.cnblogs.com/dolphin0520/p/377 ...

  2. 大数据学习(一) | 初识 Hadoop

    作者: seriouszyx 首发地址:https://seriouszyx.top/ 代码均可在 Github 上找到(求Star) 最近想要了解一些前沿技术,不能一门心思眼中只有 web,因为我目 ...

  3. 大数据学习笔记——Linux完整部署篇(实操部分)

    Linux环境搭建完整操作流程(包含mysql的安装步骤) 从现在开始,就正式进入到大数据学习的前置工作了,即Linux的学习以及安装,作为运行大数据框架的基础环境,Linux操作系统的重要性自然不言 ...

  4. 大数据学习day29-----spark09-------1. 练习: 统计店铺按月份的销售额和累计到该月的总销售额(SQL, DSL,RDD) 2. 分组topN的实现(row_number(), rank(), dense_rank()方法的区别)3. spark自定义函数-UDF

    1. 练习 数据: (1)需求1:统计有过连续3天以上销售的店铺有哪些,并且计算出连续三天以上的销售额 第一步:将每天的金额求和(同一天可能会有多个订单) SELECT sid,dt,SUM(mone ...

  5. 大数据学习系列之四 ----- Hadoop+Hive环境搭建图文详解(单机)

    引言 在大数据学习系列之一 ----- Hadoop环境搭建(单机) 成功的搭建了Hadoop的环境,在大数据学习系列之二 ----- HBase环境搭建(单机)成功搭建了HBase的环境以及相关使用 ...

  6. 大数据学习系列之五 ----- Hive整合HBase图文详解

    引言 在上一篇 大数据学习系列之四 ----- Hadoop+Hive环境搭建图文详解(单机) 和之前的大数据学习系列之二 ----- HBase环境搭建(单机) 中成功搭建了Hive和HBase的环 ...

  7. 大数据学习系列之六 ----- Hadoop+Spark环境搭建

    引言 在上一篇中 大数据学习系列之五 ----- Hive整合HBase图文详解 : http://www.panchengming.com/2017/12/18/pancm62/ 中使用Hive整合 ...

  8. 大数据学习系列之七 ----- Hadoop+Spark+Zookeeper+HBase+Hive集群搭建 图文详解

    引言 在之前的大数据学习系列中,搭建了Hadoop+Spark+HBase+Hive 环境以及一些测试.其实要说的话,我开始学习大数据的时候,搭建的就是集群,并不是单机模式和伪分布式.至于为什么先写单 ...

  9. 大数据学习系列之九---- Hive整合Spark和HBase以及相关测试

    前言 在之前的大数据学习系列之七 ----- Hadoop+Spark+Zookeeper+HBase+Hive集群搭建 中介绍了集群的环境搭建,但是在使用hive进行数据查询的时候会非常的慢,因为h ...

  10. 大数据学习之Hadoop快速入门

    1.Hadoop生态概况 Hadoop是一个由Apache基金会所开发的分布式系统集成架构,用户可以在不了解分布式底层细节情况下,开发分布式程序,充分利用集群的威力来进行高速运算与存储,具有可靠.高效 ...

随机推荐

  1. Shooting Bricks题解

    题目传送门 以后我绝对不会一直磕着一道题磕几个小时了...感觉还是自己节奏出了问题,不知为啥感觉有点小慌... 算了,其实再回头仔细看一下这个题dp的思路还是比较好想出来的,打代码之前一定要做好足够的 ...

  2. Spring事务不生效问题

    事务未生效可能造成严重的数据不一致性问题,因而保证事务生效至关重要.Spring事务是通过Spring aop实现的,所以不生效的本质问题是spring aop没生效,或者说没有代理成功,所以有必要了 ...

  3. html5的Message信息提示框

    1.定义dialog <dialog id="showDialog"> <div>您没有权限访问本页面!</div> </dialog&g ...

  4. 解决虚拟机linux系统全屏问题

    修改设置 1) 如下图右单击虚拟机名,选择[settings-],调出虚拟机设置界面. 2) 在设置界面选择[hardware]->[CD/DVD2(IDE)]->[Connection] ...

  5. PTA 7-1 公路村村通 (30分)

    PTA 7-1 公路村村通 (30分) 现有村落间道路的统计数据表中,列出了有可能建设成标准公路的若干条道路的成本,求使每个村落都有公路连通所需要的最低成本. 输入格式: 输入数据包括城镇数目正整数N ...

  6. PTA 7-2 哈夫曼编码 (30分)

    PTA 7-2 哈夫曼编码 (30分) 给定一段文字,如果我们统计出字母出现的频率,是可以根据哈夫曼算法给出一套编码,使得用此编码压缩原文可以得到最短的编码总长.然而哈夫曼编码并不是唯一的.例如对字符 ...

  7. vs2012换肤功能,vs2012主题及自定义主题

    vs2012 默认的主题只有浅色和深色两种,深色太黑了,浅色又太亮了!怎么办? 研究不少时间终于找到了怎么编辑vs2012的皮肤 现在开始吧 打开vs2012-工具--扩展和更新 在联机中搜索 The ...

  8. [atAGC034F]RNG and XOR

    令$N=2^{n}$先将$\forall 0\le i<N,a_{i}$除以$\sum_{i=0}^{N-1}a_{i}$,即变为概率 令$f_{i}$表示$i$的答案(第一次变成$i$的期望步 ...

  9. [bzoj1106]立方体大作战

    先贪心,容易发现如果两个点中间没有点对,那么一定可以先把这两个点消掉分析一下,就可以发现这样两个点的答案就是这两个点对中间不成对的点数量扫描过去,线段树维护每一个点的权值(是否会被算入答案)即可 1 ...

  10. Python集合&字典

    Python集合&字典 @ 目录 字典 字典的几种定义方式 第一种 第二种 第三种 字典的一些基本操作 通过key得到value 增加字典键值对 删除字典键值对 格式化操作 清空字典 复制字典 ...