scala访问权限

22 阅读4分钟

1.Scala的访问权限概述

Scala中的属性、方法可以通过访问控制符来设置不同的访问权限。不同的访问控制符可以决定是否可以被外部类访问。

有四种访问控制权限,分别为:

(1)默认访问权限。Scala中的默认访问权限相当于Java中的public,Scala中如果一个变量没有任何修饰符,就代表默认访问权限。作用域:全部
package level02
/*
*
* 访问权限控制
*
*   1.默认访问权限
* */

object class24 {

  //name 属性具有默认的访问权限
  class Student(var name:String) {

  }

  def main(args: Array[String]): Unit = {
    val s1 = new Student("小花","女")
    // 类的外部可以访问
    println(s1.name)
  }
}
(2)protected访问权限。作用域:本类,子类
2-1:protected : 受保护的。它的特点有如下4个:

(1) 在类的内部可以访问。

(2) 在类的外部不能访问。

(3) 在伴生对象中可以访问。

(4) 在子类中可以访问,与之对应的是:private修饰的,在子类中无法访问

package level02
/*
*
* 访问权限控制
*
*   1.默认访问权限
*   2.使用 protected(被保护的) 修饰符
*        (1) 在类的外部, 不能直接通过对象,属性的方式来访问
*        (2)
* */

object class24 {

  //name 属性具有默认的访问权限
  class Student(var name:String,protected var gender:String) {

  }

  def main(args: Array[String]): Unit = {
    val s1 = new Student("小花","女")
    // 类的外部可以访问
    println(s1.name)
    println(s1.gender)
  }
}
(3)private访问权限。作用域:类内部(伴生对象:定义方法传入类的对象)
package level02

/*
*
* 访问权限控制
*
*   1.默认访问权限
*   2.使用 protected(被保护的) 修饰符
*        (1) 在类的外部, 不能直接通过对象,属性的方式来访问
*        (2) 在子类中,通过super 来访问protected的方法
*   3. private (私有的)
*        (1) 在子类中,无法访问
* */

object class25 {

  //name 属性具有默认的访问权限
  class Father() {
    var name:String = "小花"

    protected var gender:String = "女"
    protected def test():Unit = {
      println("test")
    }

    private val age:String = "18"
    private def test1():Unit = {
      println("test1")
    }
  }

  // 在子类中,我们通过super来访问父类
  class Son extends Father{
    // protected 修饰的成员,可以在子类中访问
    super.test()
    println(gender)
    // private 修饰的成员在子类中不可访问
    // super.test1
    // println(age)
  }

  def main(args: Array[String]): Unit = {
    var son1 = new Son()

  }
}
3-1:private : 私有的。它的特点有如下三个。

(1) 在类的内部可以访问。

(2) 在类的外部不能访问。

(3) 在伴生对象中可以访问。

3-2:在伴生对象中访问
package level02

/*
*
* 访问权限控制
*
*   1.默认访问权限
*   2.使用 protected(被保护的) 修饰符
*        (1) 在类的外部, 不能直接通过对象,属性的方式来访问
*        (2) 在子类中,通过super 来访问protected的方法
*   3. private (私有的)
*        (1) 在子类中,无法访问
*        (2) 在伴生对象,伴生类中可以访问
* */

object class26 {
  class Student() {

    private var age:Int = 10

  }

  object Student {
    def test(student: Student):Unit = {
      // 在伴生对象中,可以通过对象,属性的方法来访问
      println(student.age)
    }
  }

  def main(args: Array[String]): Unit = {
    val stu = new Student()
    // private 成员,不能在类的外部,通过对象,属性的方式来访问
    Student.test(stu)
  }
}
(4)private [this] 控制方法作用域

private [this] : 更加严格的私有权限。这个属性(方法)只能在调用它的同一个实例内使用。它的特点如下: (1) 在类的内部可以访问。 (2) 在类的外部不能访问 private[this]。

(3) 在伴生对象不能访问 private[this]。

(4) 在子类中不能访问 private[this]。

package level02

/*
*
* 访问权限控制
*
*   1.默认访问权限
*   2.使用 protected(被保护的) 修饰符
*        (1) 在类的外部, 不能直接通过对象,属性的方式来访问
*        (2) 在子类中,通过super 来访问protected的方法
*   3. private (私有的)
*        (1) 在子类中,无法访问
*        (2) 在伴生对象,伴生类中可以访问
*   4.private [this] 私有,只能在当前的类中访问
*      子类无法访问,伴生对象,伴生类中不可以访问
* */

object class26 {
  class Student() {

    private var age:Int = 10

    private[this] var secret: String = "xx日, xxx事"

    def test():Unit = {
      // if() {}
      println(secret)
    }
  }

  object Student {
    def test(stu: Student):Unit = {
      // 在伴生对象中,可以通过对象,属性的方法来访问
      println(stu.age)
      // private [this] 只能在当前的类中访问
      // println(syu.secret)
    }
  }

  def main(args: Array[String]): Unit = {
    val stu = new Student()
    // private 成员,不能在类的外部,通过对象,属性的方式来访问
    Student.test(stu)
  }
}