Scala
Scala介绍
1.Spark1.6中使用的是Scala2.10。Spark2.0版本以上使用是Scala2.11版本。
2.Scala官网6个特征。
1).Java和scala可以混编
2).类型推测(自动推测类型)
3).并发和分布式(Actor)
4).特质,特征(类似java中interfaces 和 abstract结合)
5).模式匹配(类似java switch)
6).高阶函数
Scala安装使用
1.windows安装,配置环境变量
官网下载scala2.10:http://www.scala-lang.org/download/2.10.4.html
下载好后安装。双击msi包安装,记住安装的路径。
配置环境变量(和配置jdk一样)
新建SCALA_HOME
上个步骤完成后,编辑Path变量,在后面追加如下:
;%SCALA_HOME%\bin;%SCALA_HOME%\jre\bin
打开cmd,输入:scala - version 看是否显示版本号,确定是否安装成功
2.eclipse 配置scala插件(不建议)
下载插件(一定要对应eclipse版本下载)
http://scala-ide.org/download/prev-stable.html
下载好zip包后,解压如下:
将features和plugins两个文件夹拷贝到eclipse安装目录中的” dropins/scala”目录下。进入dropins,新建scala文件夹,将两个文件夹拷贝到“dropins/scala”下
3.scala ide
下载网址:http://scala-ide.org/download/sdk.html
4.idea 中配置scala插件
打开idea,close项目后,点击Configure->Plugins
搜索scala,点击Install安装
设置jdk,打开Project Structure,点击new 选择安装好的jdk路径
创建scala项目,配置scala sdk(Software Development Kit)
点击第三步,弹出选择SDK,点击Browse选择本地安装的Scala目录。选择system.
Scala基础
1.数据类型
2.变量和常量的声明
定义变量或者常量的时候,也可以写上返回的类型,一般省略,如:val a:Int = 10
常量不可再赋值
/**
* 定义变量和常量
* 变量 :用 var 定义 ,可修改
* 常量 :用 val 定义,不可修改
*/
var name = "zhangsan"
println(name)
name ="lisi"
println(name)
val gender = "m"
// gender = “m”//错误,不能给常量再赋值
3.类和对象
创建类
class Person{
val name = “zhangsan”
val age = 18
def sayName() = {
"my name is "+ name
}
}
创建对象
object Lesson_Class {
def main(args: Array[String]): Unit = {
val person = new Person()
println(person.age);
println(person.sayName())
}
}
对象中的apply方法
object中不可以传参,当创建一个object时,如果传入参数,那么会自动寻找object中的相应参数个数的apply方法。
/**
- object 单例对象中不可以传参,
- 如果在创建Object时传入参数,那么会自动根据参数的个数去Object中寻找相应的apply方法
*/
object Lesson_ObjectWithParam {
def apply(s:String) = {
println("name is "+s)
}
def apply(s:String,age:Int) = {
println("name is “+s+”,age = "+age)
}
def main(args: Array[String]): Unit = {
Lesson_ObjectWithParam(“zhangsang”)
Lesson_ObjectWithParam(“lisi”,18)
}
}
伴生类和伴生对象
class Person(xname :String , xage :Int){
var name = Person.name
val age = xage
var gender = “m”
def this(name:String,age:Int,g:String){
this(name,age)
gender = g
}
def sayName() = {
"my name is "+ name
}
}
object Person {
val name = “zhangsanfeng”
def main(args: Array[String]): Unit = {
val person = new Person(“wagnwu”,10,“f”)
println(person.age);
println(person.sayName())
println(person.gender)
}
}
注意点:
建议类名首字母大写 ,方法首字母小写,类和方法命名建议符合驼峰命名法。
scala 中的object是单例对象,相当于java中的工具类,可以看成是定义静态的方法的类。object不可以传参数。另:Trait不可以传参数
scala中的class类默认可以传参数,默认的传参数就是默认的构造函数。
重写构造函数的时候,必须要调用默认的构造函数。
class 类属性自带getter ,setter方法。
使用object时,不用new,使用class时要new ,并且new的时候,class中除了方法不执行,其他都执行。
如果在同一个文件中,object对象和class类的名称相同,则这个对象就是这个类的伴生对象,这个类就是这个对象的伴生类。可以互相访问私有变量。
4.if else
/**
* if else
*/
val age =18
if (age < 18 ){
println("no allow")
}else if (18<=age&&age<=20){
println("allow with other")
}else{
println("allow self")
}
5.for ,while,do…while
1.to和until 的用法(不带步长,带步长区别)
/**
* to和until
* 例:
* 1 to 10 返回1到10的Range数组,包含10
* 1 until 10 返回1到10 Range数组 ,不包含10
*/
println(1 to 10 )//打印 1, 2, 3, 4, 5, 6, 7, 8, 9, 10
println(1.to(10))//与上面等价,打印 1, 2, 3, 4, 5, 6, 7, 8, 9, 10
println(1 to (10 ,2))//步长为2,从1开始打印 ,1,3,5,7,9
println(1.to(10, 2))
println(1 until 10 ) //不包含最后一个数,打印 1,2,3,4,5,6,7,8,9
println(1.until(10))//与上面等价
println(1 until (10 ,3 ))//步长为2,从1开始打印,打印1,4,7
2.创建for循环
/**
* for 循环
*
*/
for( i <- 1 to 10 ){
println(i)
}
3.创建多层for循环
//可以分号隔开,写入