大数据学习之初识scala

变量

var:可变变量
val:不可变变量

函数

def:定义函数的关键字
函数类型
(1) 方法:成员函数
在这里插入图片描述
(2) 局部函数
(3) 高阶方法:把函数作为输入参数,类似其他语言的迭代
(4) 函数字面量:源代码中的匿名函数(可作高阶方法中的参数,也可赋值给变量)
(5) 闭包:可以使用非参数、非局部变量函数字面体(如例子中的seed就是从作用域获得而非函数体获得的)
在这里插入图片描述

类是由字段(变量)和方法(函数)构成的。
类的分类
(1) 类
在这里插入图片描述
(2) 单例:只可以实例化一次的类,用关键字object来定义,如:

	object DatabaseConnection{
		def open(name: String): Int ={
			...
		}
	}

(3) 样本类:使用case关键字修饰
使用new关键字就可以创建一个样本类的类实例
所有参数隐式获得val前缀,所以可以从外部访问参数
scala为样本类添加了方法toString、hashcode、equals、copy
在这里插入图片描述

模式匹配

用match关键字代替switch关键字,替代多层if-else语句,返回的是一个值
在这里插入图片描述在这里插入图片描述

操作符

scala中运算符的本质都是操作符,如

	val z = x+y
	val z = x.+(y)

上述两句等价。

特质

特质类似类继承关系中的接口,对比如下:

比较1Java接口Scala特质
区别只有接口没有实现,继承接口必须实现接口方法可以有方法和字段
比较2Java抽象类Scala特质
区别一个类只能继承一个抽象类一个类可以继承多个特质

在这里插入图片描述

元组

元组是一个容器,存放两个或多个不同类型的元素,并且是不可修改的。
作用:把一些不相关的元素聚合在一起
在这里插入图片描述

补充:(1) 所有元素属于同一类型时,可以使用集合(数组、列表)
(2) 元素使不同类型但它们之间有联系时,可以使用类

Option类型

Option类型是一种数据类型,它可以在函数或方法中作为返回值,表示的值是可选的,要么有值(样本类Some的实例),要么无值(单例对象None的实例)。
在这里插入图片描述
记录 2019.09.09

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值