scala tutorial

来源:互联网 发布:oss 阿里云 编辑:程序博客网 时间:2024/05/16 14:31

1 scala的面向对象:

在scala中,万物皆对象。通过class和traits来定义对象的类型和行为。

2 函数式 scala:

scala死一种函数式编程语言,其中任何函数都表示一个值,其可以通过轻量级的语法定义匿名函数,并且支持函数间的值传递,递归调用以及柯里化currying.

3 unified types:

在scala中,所有的值和函数都是object.如下图展示的scala中的继承图:

其中,scala.Any是所有类的父类,其有2个子类:scala.AnyVal(value类型) 和scala.AnyRef (reference类型)。

所有的value类型和JAVA中的基本数据类型类似,都是预定义的;其余的类都属于reference类型;

因而,所以用户自定义的类都默认是scala.AnyRef的子类;所有用户自定义的类都默认继承了scala.ScalaObject。

并且,scala运行时环境的类不继承scala.ScalaObject。

若scala是运行在Java runtime environment,则scala.AnyRef对应的是JAVA中的java.lang.Object。

下图同时也展示了scala中值类型间的隐式转换。


Scala Type Hierarchy

e.g.

  1. objectUnifiedTypesextendsApp{
  2. valset=new scala.collection.mutable.LinkedHashSet[Any]
  3. set+="This is a string"// add a string
  4. set+=732// add a number
  5. set+='c'// add a character
  6. set+=true// add a boolean value
  7. set+= main _// add the main function
  8. val iter:Iterator[Any]=set.iterator
  9. while(iter.hasNext){
  10. println(iter.next.toString())
  11. }
  12. }
 输出如下:

  1. Thisis astring
  2. 732
  3. c
  4. true
  5. <function>
最终,所有类型都被转换成string类型并输出。万物皆对象,main function也可以输出。

0 0
原创粉丝点击