(一)Scala的访问权限概述
Scala中的属性、方法可以通过访问控制符来设置不同的访问权限。不同的访问控制符可以决定是否可以被外部类访问。
有四种访问控制权限,分别为:
(1)默认访问权限。Scala中的默认访问权限相当于Java中的public,Scala中如果一个变量没有任何修饰符,就代表默认访问权限。作用域:全部
(2)protected访问权限。作用域:本类,子类
(3)private访问权限。作用域:类内部(伴生对象:定义方法传入类的对象)
(4)private[this]访问权限。
(二)private访问权限
private : 私有的
特点:
(1) 在类的内部可以访问。
(2) 在类的外部不能访问。
(3) 在伴生对象中可以访问。
(三)protected访问权限
protected : 受保护的
特点:
(1) 在类的内部可以访问。
(2) 在类的外部不能访问。
(3) 在伴生对象中可以访问。
(4) 在子类中可以访问,与之对应的是:private修饰的,在子类中无法访问
(四)private[this]控制方法作用域
private [this] : 更加严格的私有权限。这个属性(方法)只能在调用它的同一个实例内使用
特点:
(1) 在类的内部可以访问。
(2) 在类的外部不能访问 private[this]。
(3) 在伴生对象不能访问 private[this]。
(4) 在子类中不能访问 private[this]。
- 代码如下:
package level02
object Person {
def test(p:Person): Unit = {
// private 在伴生对象中可以访问!
println(p.password)
// private[this] 在伴生对象中不能访问的
// println(p.money)
}
}
class Person() {
var name: String = "xxx" // 公开的
protected var birthday:String = "2000-10-10"
private var password:String="123456"
private[this] var money:Int=100
def tt():Unit = {
println(money)
}
}
class Son extends Person(){
// 2. protected在子类中可访问
println(birthday)
// 3. private在子类中不能访问的
// println(password)
}
def main(args: Array[String]): Unit = {
val p1 = new Person()
println(p1.name)
// 2. protected在类的外部无法访问
// println(p1.birthday)
new Son()
// 3. 在伴生对象中访问 类的私有成员
Person.test(p1)
}
总结:
访问权限控制
- 公开的。不写修饰符
- protected,保护的 在类的外部不能访问! 在子类中访问。
- private,私有的 在类的外部不能访问! 在子类中不能访问 在伴生对象中可以访问!
- private[this] 只能被当前对象中使用 在类的内部使用