定义一个简单的类
getter与setter
仅暴露field的getter方法
private[this]的使用
Java风格的getter和setter方法
辅助constructor
主constructor
内部类
小结
定义不带private的var field,此时scala生成的面向JVM的类时,会定义为private的name字段,并提供public的getter和setter方法 而如果使用private修饰field,则生成的getter和setter也是private的 如果定义val field,则只会生成getter方法 如果不希望生成setter和getter方法,则将field声明为private[this]
调用getter和setter方法,分别叫做name和name_ =
// 定义不带private的var field,此时scala生成的面向JVM的类时,会定义为private的name字段,并提供public的getter和setter方法 // 而如果使用private修饰field,则生成的getter和setter也是private的 // 如果定义val field,则只会生成getter方法 // 如果不希望生成setter和getter方法,则将field声明为private[this] class Student { var name = "leo" } // 调用getter和setter方法,分别叫做name和name_ = val leo = new Student print(leo.name) leo.name = "leo1"如果你不希望field有setter方法,则可以定义为val,但是此时就再也不能更改field的值了 但是如果希望能够仅仅暴露出一个getter方法,并且还能通过某些方法更改field的值,那么需要综合使用private以及自定义getter方法 此时,由于field是private的,所以setter和getter都是private,对外界没有暴露;自己可以实现修改field值的方法;自己可以覆盖getter方法
// 如果你不希望field有setter方法,则可以定义为val,但是此时就再也不能更改field的值了 // 但是如果希望能够仅仅暴露出一个getter方法,并且还能通过某些方法更改field的值,那么需要综合使用private以及自定义getter方法 // 此时,由于field是private的,所以setter和getter都是private,对外界没有暴露;自己可以实现修改field值的方法;自己可以覆盖getter方法 class Student { private var myName = "leo" def updateName(newName: String) { if(newName == "leo1") myName = newName else print("not accept this new name!!!") } def name = "your name is " + myName }如果将field使用private来修饰,那么代表这个field是类私有的,在类的方法中,可以直接访问类的其他对象的private field 这种情况下,如果不希望field被其他对象访问到,那么可以使用private[this],意味着对象私有的field,只有本对象内可以访问到
// 如果将field使用private来修饰,那么代表这个field是类私有的,在类的方法中,可以直接访问类的其他对象的private field // 这种情况下,如果不希望field被其他对象访问到,那么可以使用private[this],意味着对象私有的field,只有本对象内可以访问到 class Student1 { private var myAge = 0 def age_=(newValue: Int) { if (newValue > 0) myAge = newValue else print("illegal age!") } def age = myAge def older(s: Student1) = { myAge > s.myAge } } // 定义一个类报错 class Student2 { private[this] var myAge = 0 def age_=(newValue: Int) { if (newValue > 0) myAge = newValue else print("illegal age!") } def age = myAge def older(s: Student2) = { myAge > s.myAge } }Scala的getter和setter方法的命名与java是不同的,是field和field_=的方式 如果要让scala自动生成java风格的getter和setter方法,只要给field添加@BeanProperty注解即可 此时会生成4个方法,name: String、name_=(newValue: String): Unit、getName(): String、setName(newValue: String): Unit
// Scala的getter和setter方法的命名与java是不同的,是field和field_=的方式 // 如果要让scala自动生成java风格的getter和setter方法,只要给field添加@BeanProperty注解即可 // 此时会生成4个方法,name: String、name_=(newValue: String): Unit、getName(): String、setName(newValue: String): Unit // import scala.reflect.BeanProperty 修改为: import scala.beans.BeanProperty class Student { @BeanProperty var name: String = _ } class Student(@BeanProperty var name: String) val s = new Student s.setName("leo") s.getName()Scala中,可以给类定义多个辅助constructor,类似于java中的构造函数重载辅助constructor之间可以互相调用,而且必须第一行调用主constructor
// Scala中,可以给类定义多个辅助constructor,类似于java中的构造函数重载 // 辅助constructor之间可以互相调用,而且必须第一行调用主constructor class Student { private var name = "" private var age = 0 def this(name: String) { this() this.name = name } def this(name: String, age: Int) { this(name) this.age = age } }Scala中,主constructor是与类名放在一起的,与java不同
而且类中,没有定义在任何方法或者是代码块之中的代码,就是主constructor的代码,这点感觉没有java那么清晰
主constructor中还可以通过使用默认参数,来给参数默认的值
如果主constrcutor传入的参数什么修饰都没有,比如name: String,那么如果类内部的方法使用到了,则会声明为private[this] name;否则没有该field,就只能被constructor代码使用而已
// Scala中,主constructor是与类名放在一起的,与java不同 // 而且类中,没有定义在任何方法或者是代码块之中的代码,就是主constructor的代码,这点感觉没有java那么清晰 class Student(val name: String, val age: Int) { println("your name is " + name + ", your age is " + age) } // 主constructor中还可以通过使用默认参数,来给参数默认的值 class Student(val name: String = "leo", val age: Int = 30) { println("your name is " + name + ", your age is " + age) } // 如果主constrcutor传入的参数什么修饰都没有,比如name: String,那么如果类内部的方法使用到了,则会声明为private[this] name;否则没有该field,就只能被constructor代码使用而已Scala中,同样可以在类中定义内部类;但是与java不同的是,每个外部类的对象的内部类,都是不同的类
// Scala中,同样可以在类中定义内部类;但是与java不同的是,每个外部类的对象的内部类,都是不同的类 import scala.collection.mutable.ArrayBuffer class Class { class Student(val name: String) {} val students = new ArrayBuffer[Student] def getStudent(name: String) = { new Student(name) } } val c1 = new Class val s1 = c1.getStudent("leo") c1.students += s1 val c2 = new Class val s2 = c2.getStudent("leo") c1.students += s2大致叙述了类中的field及方法的三种定义方式及使用场景,以及constructor 也就是常说的构造函数,已经辅助constructor也就是常说的重载构造函数,相互调用的方式和java都是雷同的,以及到后面说的内部类,其实就是一句话:自己用自己的,内部类外部的对象不同则内部类也不同,不能混在一起进行使用。ok,就这么多了。熟能生巧,多敲多练吧!@!!
