scala学习之scala与java的一些区别(二)

常自强
2023-12-01

不带命令行参数的简化main方法:

object app1 extends Application {

    println("hello world")

}

Scalaimport可以只在局部作用域内生效;

可以格式 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)

max

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没有breakcontinue语法!需要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!)


 类似资料: