成员变量
在java中,咱们定义一个类是这样的:
public class JavaPerson {
private String name;
private Integer age;
// 省略name、age的setter和getter办法
}
调用是这样的:
public static void main(String[] args) {
JavaPerson javaPerson = new JavaPerson();
javaPerson.setAge(18);
javaPerson.setName("张三");
System.out.println("姓名:" + javaPerson.getName() + ",年龄:" + javaPerson.getAge());
}
在scala中,会比拟简洁一点,类的定义如下,因为scala中变量的定义都要有初始值,所以咱们这边能够定义为下划线阐明是空。
class ScalaPerson {
var age: Integer = _
var name: String = _
}
调用是这样的:
val scalaPerson = new ScalaPerson
scalaPerson.age = 18
scalaPerson.name = "张三"
println(s"姓名:${scalaPerson.name},年龄:${scalaPerson.age}")
看起来咱们是间接调用对象的属性,实际上是scala暗藏了setter和getter,咱们看看反编译的代码,这个是ScalaPerson反编译后的代码,能够看到他的属性其实是private的,而后还有相似setter和getter的办法,比方age()和age_$eq()办法
有时候为了兼容java框架,须要setter和getter办法,咱们只有在属性下面加@BeanProperty
注解就能够用setter和getter办法了。
class ScalaPerson2 {
@BeanProperty
var age: Integer = _
var name: String = _
}
object ScalaPerson2 {
def main(args: Array[String]): Unit = {
val scalaPerson = new ScalaPerson2
scalaPerson.age = 17
scalaPerson.setAge(18)
scalaPerson.name = "张三"
println(s"姓名:${scalaPerson.name},年龄:${scalaPerson.getAge}")
}
}
咱们晓得,scala的变量申明包含val和var,如果在类中定义val,那这个变量就是final类型的,比方下面的name通过val定义,他相似于上面的java代码,并且只有get办法。
private final String name = "张三";
结构器
无参结构
无参的话,能够在类名加括号,也能够不加
class ScalaConstruct1 {
var name: String = _
var age: Int = _
}
object ScalaConstruct1 {
def main(args: Array[String]): Unit = {
val construct = new ScalaConstruct1
construct.name = "张三"
construct.age = 18
}
}
有参结构器
有参的话,变量的修饰符包含没有修饰符、val和var。上面用例子来阐明这三种状况。
class ScalaConstruct2(param1: String, var param2: String, val param3: String) {
}
object ScalaConstruct2 {
def main(args: Array[String]): Unit = {
val construct = new ScalaConstruct2("aa", "bb", "cc")
//println(construct.param1) //error
//construct.param1 = "aaa" // error
construct.param2 = "bbb"
println(construct.param2)
//construct.param3 = "ccc"// error
println(construct.param3)
}
}
param1是没有修饰符的,所以他是ScalaConstruct2的局部变量,这样在类里面就不能调用了。
param2是能够批改的,所以既能够读取也能够批改。
param3是不能批改的,所以只能读取不能批改。
主结构器
下面无参的以及放在类名前面的有参结构器都是主结构器,另外主结构器还能够执行类中可能执行的语句。
所以上面运行后会间接打印hello ScalaConstruct3
class ScalaConstruct3() {
println("hello ScalaConstruct3")
}
object ScalaConstruct3{
def main(args: Array[String]): Unit = {
new ScalaConstruct3
}
}
辅助结构器
java中用类命当做结构器的名称,在scala中辅助结构器用this来申明,他必须间接或者间接的调用主结构器。类的实例化,跟java相似。
class ScalaConstruct4() {
var age: Int = _
var name: String = _
def this(name: String) {
this()
this.name = name
}
def this(name: String, age: Int) {
this(name)
this.age = age
}
}
object ScalaConstruct4 {
def main(args: Array[String]): Unit = {
new ScalaConstruct4
new ScalaConstruct4("张三")
new ScalaConstruct4("张三",18)
}
}
发表回复