Scala安装使用

本文详细介绍了Scala的安装过程,包括Windows环境变量配置、Eclipse插件安装、Scala IDE和IntelliJ IDEA的配置。此外,文章深入讲解了Scala的基础知识,如数据类型、变量声明、类和对象的创建,特别强调了对象中的apply方法和伴生类的概念。文章还探讨了Scala的循环结构、方法与函数,包括递归、默认参数、匿名函数、高阶函数等内容,展示了Scala的灵活与强大。
摘要由CSDN通过智能技术生成

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循环
//可以分号隔开,写入
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值