Scala入门

Scala是基于JVM的一门编程语言,使用字节码文件在JVM上运行,可以与JAVA代码无缝调用。
Scala是Spark的编程语言,看源码和编写Spark处理程序会用到。

安装

Ctrl+Shift+P
输入:package,选择package control:package Install。
输入:repl,选择sublimeREPL
Tools -> SublimeREPL -> Scala

基本

分行符;

可以使用;作为行结束,也可以不使用,但是在一行需要多条语句时候需要使用

块表达式{},作为一个表达式是有值的(其实就是省略了return)

可以像JAVA一样使用{}包含代码块,包含的部分作为块执行,最后一个语句的值作为块表达式的返回值

var d = if(a<10){b = b + 1;c+1}
//相当于,最后一行作为返回值
var d = if(a<10){
	b = b + 1
	c = c + 1
}

注释与JAVA相同

缩进问题:与Python不同,不是靠缩进实现代码块的

var d = if(a<10)
	b = b + 1
	c = c + 1//这一行被当做新的一条语句来执行

Hello world

REPL:(Read Evaluation Print Loop)Scala解释器会快速编译成字节码文件,提交给JVM执行然后返回结果。

计算表达式:直接输入计算表达式,Scala会像Python一样直接返回计算结果,如果你没有定义一个变量来接收,将使用内置变量**res1:Int = **来打印变量和类型

scala> 1+1
res1: Int = 2

内置变量:上文的变量是可以直接调用的

scala> 1+res2
res3: Int = 3

使用tab自动补全

变量

val变量(常量,不可改变)推荐使用

val result = 1 + 1

var变量(正常的变量)

在Spark编程中,通常建议使用val来声明,防止在复杂的大数据系统中值被错误的更改
在JAVA中这种大型复杂系统开发中,同样用了类似的特性,如不可变类(Immuable class),里面的变量使用final定义,从而提升系统的健壮性(robust鲁棒性)

var res = 2

指定类型(用于使用父类的类型来包容更小的类型)

Scala在声明变量时候可以指定类型,如不声明,scala会根据值自动判断类型

var name:String = "hello"
var name:Any = 123

多个变量声明

//错误
var i1,i2 = 1,2
var i1 = 1,i2 = 2

//正确
var i1,i2 = 100

数据类型

基本数据类型:Byte Char Short Int Long Float Double Boolean

scala中,没有基本数据类型和包装数据类型的区别,都是类。全都拥有方法。对于底层的数据类型和引用类型的转换自动完成

1.toString
1.toString()

加强版数据类型:StingOps RichInt RichDouble RichChar使用这些增强类来增加基本数据类型的功能或函数。然而这一切都是自动完成

1.to(10)
res0: scala.collection.immutable.Range.Inclusive = Range 1 to 10

操作符:在scala中的操作符其实也是函数,函数也能做操作符

支持 += -= 但不支持 -- ++

1 + 1		等于	1.+(1)
1.to(10)	等于	1 to 10

函数

函数调用:需要传参数才需要括号,不需要参数可以省略括号

max(1,2)
"Hello".toUpperCase

apply函数:使用 类名()即可实例化对象,实际上相当于调用了类名.apply(),我们需要在类中def apply():

//实例化对象:
Array(1,2,3,4)
//相当于调用了,StingOps类中的apply方法
Array.apply(1,2,3,4)
res0: Array[Int] = Array(1, 2, 3, 4)

条件控制及循环

IF

有值的if表达式

//将会返回if/else最后的值作为表达式的值(感觉就是省略了return语句)
val age = 30;
var isAdult = if (age > 18) 1 else 0

//另一种写法(不常用)
var isAdult = -1;if (age > 18) isAdult = 1 else isAdult = 0

返回值类型

//if和else中返回值类型不同时,返回值类型取两种类型的**父类型**
age = 30;if (age > 18) "adult" else 0
res0: Any = adult

//当else语句不存在时,默认else的类型为**Unit**也用**()**表示,相当于Java中的null
age = 30;if (age < 18) "adult" 
res0: AnyVal = ()

多行可以使用{}/:paste进入粘贴模式(无需{})

循环

while do 循环

var n = 10 while (n > 0) {
  print(n + " ")
  n -= 1 
}

Scala没有正儿八经的for循环

// 1.简易for循环
for (i <- 1 to 10){
  println(i)
}
//1 to 10:Range(1,2,3,4,5,6,7,8,9,10)

// 2.使用until忽略上界限
for(i <- 1 until 10){
	println(i)
}
//1 until 10:Range(1,2,3,4,5,6,7,8,9)

// 3.增强for循环(更体现面向对象)
for(i <- "Hello world"){
	print(i+" ")
}

高级for循环

循环嵌套

for (i <- 1 to 9; j <- 1 to 9) {
	printf("i=%d j=%d\n",i,j)
	//这样就实现了循环嵌套,总共执行4*4次
}
//结果如下
i=1 j=1
i=1 j=2
i=1 j=3
i=1 j=4
i=2 j=1
i=2 j=2
i=2 j=3
i=2 j=4
...

//完全等效的JAVA代码
for (int i = 0; i < 10; i++) {
	for (int j = 0; j < 10; j++) {
		System.out.println("i=" + i + "j=" + j + "\n");
	}
}

if守卫

for(i <- 1 to 100 if i % 2 == 0){
	println(i)
}

for推导式

for(i<- 1 to 10) yield i
res0: scala.collection.immutable.IndexedSeq[Int] = Vector(1, 2, 3, 4, 5, 6, 7, 8, 9, 10)

跳出for循环(!!丧心病狂!!)

import scala.util.control.Breaks

val mybreaks = new Breaks

import mybreaks.{break, breakable}

breakable {
  var n = 10
  for (c <- "Helloworld") {
    print(c + " ")
    if (n == 5 ) break()
    n -= 1
  }
}

输入输出

// use java API
System.out.print("ABC")
System.out.println("ABC")

// Use scala API
print("ABC")
print("ABC")

// printf %s %d 必须使用print
printf("My name is %s,I'm %d yesrs old","James",20) 

// input from Terminal
readLine("This will show in Terminal and wait for you input")			//弃用
readInt()			//将会强转为Int

import scala.io.StdIn		//新标准
readf("This is a new read in method")
posted @ 2017-08-29 16:52  岑忠满  阅读(378)  评论(0编辑  收藏  举报