scala基础备忘

时间:2023-03-09 05:16:15
scala基础备忘

声明一个变量

scala基础备忘

声明一个常量

scala基础备忘

显式指定类型

scala基础备忘

定义一个main函数

package org.admln.scala

class HelloScala {

}
object HelloScala {
def main (args: Array[String]) {
println("hello scala")
}
}

定义一个普通函数

package org.admln.scala

class HelloScala {

}
object HelloScala {
def main (args: Array[String]) {
println(hello("scala"))
} def hello(name : String) : String = {
"hello " + name
}
}

函数不带参数时可以省略括号

package org.admln.scala

class HelloScala {

}
object HelloScala {
def main (args: Array[String]) {
println(hello())
} def hello() : String = {
"hello scala"
}
}

定义一个匿名函数

package org.admln.scala

class HelloScala {

}
object HelloScala {
def main (args: Array[String]) {
println(add(,))
} def add = (x : Int,y : Int) => x + y
}

把函数赋给一个常量

package org.admln.scala

class HelloScala {

}
object HelloScala {
def main (args: Array[String]) {
println(add(,))
} val add = (x : Int,y : Int) => x + y
}

柯里化

package org.admln.scala

class HelloScala {

}
object HelloScala {
def main (args: Array[String]) {
println(add()())
} def add(x : Int)(y : Int) = x + y
}

可变参数

package org.admln.scala

class HelloScala {

}
object HelloScala {
def main (args: Array[String]) {
println(variable("hello","admln"))
} def variable(s : String*) = {
s.foreach(x => println(x))
}
}

参数默认值

package org.admln.scala

class HelloScala {

}
object HelloScala {
def main (args: Array[String]) {
println(theDefault())
println(theDefault("scala"))
} def theDefault(s : String="admln") : String= {
"hello " + s
}
}

判断表达式

package org.admln.scala

class HelloScala {

}
object HelloScala {
def main (args: Array[String]) {
val num = ;
val result = if(num > ) else
println(result)
}
}

while循环表达式

package org.admln.scala

class HelloScala {

}
object HelloScala {
def main (args: Array[String]) {
var (n,r) = (,)
while(n>) {
r = r + n
n = n -
}
println(r)
}
}

for循环表达式

package org.admln.scala

class HelloScala {

}
object HelloScala {
def main (args: Array[String]) {
//1<=10
for(i <- to ) {
println(i)
}
//1<10
for(i <- until ) {
println(i)
}
   //只输出偶数
for(i <- to if i % == ) {
println(i)
}
}
}

创建一个类

package org.admln.scala

class HelloScala {

}
class Person {
var name : String = _
val age =
}
object MyPerson {
def main(args: Array[String]) {
val p = new Person
p.name = "admln"
println(p.name + " " + p.age)
}
}

使用私有属性(外部不能访问)

package org.admln.scala

class HelloScala {

}
class Person {
var name : String = _
val age =
private[this] val gender = "male"
}
object MyPerson {
def main(args: Array[String]) {
val p = new Person
p.name = "admln"
println(p.name + " " + p.age)
}
}

构造器

package org.admln.scala

class HelloScala {

}
class Person(var name : String,val age : Int){
println("main constructor")
var gender : String = _
def this(name : String,age : Int,gender : String) {
this(name,age)
this.gender = gender
}
}
object MyPerson {
def main(args: Array[String]) {
val p = new Person("admln",,"male")
println(p.name + " " + p.age)
}
}

继承

package org.admln.scala

class HelloScala {

}
class Person(var name : String,val age : Int){
println("main constructor")
var gender : String = _
def this(name : String,age : Int,gender : String) {
this(name,age)
this.gender = gender
}
}
class Student(name : String,age : Int,val major : String) extends Person(name,age) {
println("subclass is person,major is" + major)
}
object MyPerson {
def main(args: Array[String]) {
val s = new Student("admln",,"spark")
}
}

覆写父类的方法和字段

package org.admln.scala

class HelloScala {

}
class Person(var name : String,val age : Int){
println("main constructor")
var gender : String = "mail"
def this(name : String,age : Int,gender : String) {
this(name,age)
this.gender = gender
}
val school = "usa"
}
class Student(name : String,age : Int,val major : String) extends Person(name,age) {
println("subclass is person,major is" + major)
override def toString = "override method"
override val school = "china"
}
object MyPerson {
def main(args: Array[String]) {
val s = new Student("admln",,"spark")
println(s.toString)
println(s.gender)
}
}

抽象类

package org.admln.scala

class HelloScala {

}
abstract class Person {
def speak
var name : String
val age : Int
}
class Worker extends Person {
def speak {
println("speak")
}
var name = "admln"
val age =
}
object HelloScala extends App {
val worker = new Worker
worker.speak
println(worker.name + " " + worker.age)
}

App是trait的子类,内部实现了main方法并管理我们写的代码

trait

trait中可以带有实现的方法,也可以带有抽象方法,使用trait的方式是使用with混入类中

 package org.admln.scala

 class UseTrait {

 }
trait Logger {
def log(msg : String) {
println("log: " + msg)
}
} class ConcreteLogger extends Logger {
def concreteLog {
log("It's admln")
}
} object UseTrait {
def main(args: Array[String]) {
val logger = new ConcreteLogger
logger.concreteLog
}
}

覆写父类的抽象方法(不用使用override关键字)

package org.admln.scala

class UseTrait {

}
trait Logger {
def log(msg : String)
} trait ConcreteLogger extends Logger {
def log(msg : String) {
println("log: " + msg)
}
} class Test extends ConcreteLogger {
def test {
log("It's admln")
}
} object UseTrait {
def main(args: Array[String]) {
val test = new Test
test.test
}
}

如果子trait覆写父trait已经实现的方法,就必须使用override关键字

package org.admln.scala

class UseTrait {

}
trait Logger {
def log(msg : String) {
println("log: " + msg)
}
} trait ConcreteLogger extends Logger {
override def log(msg : String) {
println(" child log: " + msg)
}
} class Test extends ConcreteLogger {
def test {
log("It's admln")
}
} object UseTrait {
def main(args: Array[String]) {
val test = new Test
test.test
}
}

在对象中混入trait

package org.admln.scala

class UseTrait {

}
trait Logger {
def log(msg : String) {
println("log: " + msg)
}
} trait ConcreteLogger extends Logger {
override def log(msg : String) {
println(" child log: " + msg)
}
} class Test extends Logger{
def test {
log("It's admln")
}
} object UseTrait {
def main(args: Array[String]) {
val test = new Test with ConcreteLogger
test.test
}
}

apply方法和静态方法

package org.admln.scala

class UsageOfApply {

}

class ApplyTest {
def test {
println("test")
}
} object ApplyTest {
def apply() = new ApplyTest
def staticTest {
println("It's static method")
}
} object UsageOfApply {
def main(args: Array[String]) {
ApplyTest.staticTest
val at = ApplyTest()
at.test
}
}

object 中的方法和属性都是静态的,所以是单例对象的理想载体
object本身就是一个单例对象


函数式编程,把运算过程尽量写成一系列嵌套的函数调用

函数的定义

def 函数名称(变量名称 : 变量类型) : 函数返回值类型 = { 函数体 }

如果函数仅包含一条语句,那么花括号可以选择不写

scala基础备忘

值函数

scala基础备忘

匿名函数

(参数名称 : 参数类型) => 表达式

把匿名函数赋值给一个常量

scala基础备忘


闭包

代码与用到的非局部变量的混合

闭包 = 代码 + 非局部变量

scala基础备忘


高阶函数map函数

scala基础备忘

下划线代表数组中的每一个元素

高阶函数filter函数

scala基础备忘

高阶函数reduce函数

scala基础备忘


scala中的集合:List、Set、Tuple、Map

它们内部都是以apply方式来完成实例化的

List和Set

scala基础备忘

和java中的Set一样,里面不会存在相同元素

Tuple

scala基础备忘

下标从1开始

Map

scala基础备忘

Option

Option代表一个可有可无的值,有两个子类:Some和None

scala基础备忘

zip操作

scala基础备忘

partition操作

scala基础备忘

flatten操作

scala基础备忘

flatmap操作:map和flatten的结合

scala基础备忘