不带命令行参数的简化main方法:
object app1 extends Application {
println("hello world")
}
Scala的import可以只在局部作用域内生效;
可以格式 “import javax.swing.{JFrame=>jf}”来声明类型的别名。
jf.show()
l import javax.swing._
l import java.util.{List, Map}
l import java.util._, java.io._
Scala 缺省导入如下包:
l java.lang.*
l scala.*
l scala.Predef
for .. yield
把每次循环的结果“移”进一个集合(类型和循环内的一致)
for {子句} yield {循环体}
正确:
for (e<-List(1,2,3)) yield (e*e) // List(1,4,9)
错误:
for (e<-List(1,2,3)) { yield e*e } // 语法错误,yield不能在任何括号内
reduceLeft:
reduceLeft 方法首先应用于前两个元素,然后再应用于第一次应用的结果和接下去的一个元素,等等,直至整个列表。例如
计算阶乘:
def fac(n: Int) = 1 to n reduceLeft(_*_)
fac(5) // 5*4*3*2 = 120
相当于:
((((1*2)*3)*4)*5)
计算sum:
List(2,4,6).reduceLeft(_+_) // 12
相当于:
((2+4)+6)
List(1,4,9,6,7).reduceLeft( (x,y)=> if (x>y) x else y ) // 9
或者简化为:
List(1,4,9,6,7).reduceLeft(_ max _) // 9
相当于:
((((1 max 4) max 9) max 6) max 7)
Scala中没有break和continue语法!需要break得加辅助boolean变量,或者用库(continue没有).
Scala没有操作符,更谈不上操作符重载;+-/*都是方法名,如1+2其实是(1).+(2)
阶乘:
第一步:写函数
def factorial(n: Int) = 1 to n reduceLeft(_*_)
第二步:定义 "!" 函数
class m1(n: Int) {
def ! = factorial(n)
}
第三步:使用
val n = 100
printf("%d! = %s\n", n, (n!)) // n! 相当于 new m1(n).!()
println(10!)