Scala 中的访问修饰符

在Scala中,面向对象的权限控制主要通过访问修饰符来实现。Scala提供了以下几种访问修饰符来控制类、对象、成员变量和方法的访问权限:

1. 默认访问权限(无修饰符)

  • 如果没有指定任何访问修饰符,成员默认是public的,即可以在任何地方访问。

2. private 修饰符

  • private 修饰的成员只能在定义该成员的类或对象内部访问。

  • 子类无法访问父类的 private 成员。

Scala 复制代码
class MyClass {
  private val secret = 42
  def printSecret(): Unit = {
    println(secret)  // 可以访问
  }
}

val obj = new MyClass
// obj.secret  // 错误:无法访问 private 成员
obj.printSecret()  // 输出: 42

3. protected 修饰符

  • protected 修饰的成员可以在定义该成员的类及其子类中访问。

  • 与 Java 不同,Scala 的 protected 成员不能在同一包的其他类中访问。

Scala 复制代码
class Parent {
  protected val value = 10
}

class Child extends Parent {
  def printValue(): Unit = {
    println(value)  // 可以访问
  }
}

val child = new Child
child.printValue()  // 输出: 10
// child.value  // 错误:无法访问 protected 成员

4. private[this] 修饰符

  • private[this] 修饰的成员只能在当前实例中访问,即使是同一个类的其他实例也无法访问。

  • 这种修饰符通常用于确保对象的封装性。

Scala 复制代码
class MyClass {
  private[this] val secret = 42
  def compare(other: MyClass): Boolean = {
    // this.secret == other.secret  // 错误:无法访问 other.secret
    this.secret == 42  // 只能访问当前实例的 secret
  }
}

5. protected[this] 修饰符

  • protected[this] 修饰的成员只能在当前实例及其子类的实例中访问。

  • private[this] 类似,但允许子类访问。

Scala 复制代码
class Parent {
  protected[this] val value = 10
}

class Child extends Parent {
  def compare(other: Child): Boolean = {
    // this.value == other.value  // 错误:无法访问 other.value
    this.value == 10  // 只能访问当前实例的 value
  }
}

6. 包级访问权限

  • Scala 允许通过 private[包名]protected[包名] 来限制成员的访问范围。

  • 这种修饰符允许成员在指定的包及其子包中访问。

Scala 复制代码
package com.example {
  class MyClass {
    private[example] val value = 42  // 只能在 com.example 包及其子包中访问
  }
}

package com.example.sub {
  class SubClass {
    def printValue(): Unit = {
      val obj = new com.example.MyClass
      println(obj.value)  // 可以访问
    }
  }
}

总结

  • private:仅限类内部访问。

  • protected:类及其子类访问。

  • private[this]:仅限当前实例访问。

  • protected[this]:当前实例及其子类实例访问。

  • 包级访问:通过 private[包名]protected[包名] 控制包内访问权限。

Scala 的权限控制机制比 Java 更加灵活,能够更好地支持封装和模块化设计。

相关推荐
武子康18 小时前
大数据-237 离线数仓 - Hive 广告业务实战:ODS→DWD 事件解析、广告明细与转化分析落地
大数据·后端·apache hive
大大大大晴天20 小时前
Flink生产问题排障-Kryo serializer scala extensions are not available
大数据·flink
武子康3 天前
大数据-236 离线数仓 - 会员指标验证、DataX 导出与广告业务 ODS/DWD/ADS 全流程
大数据·后端·apache hive
武子康4 天前
大数据-235 离线数仓 - 实战:Flume+HDFS+Hive 搭建 ODS/DWD/DWS/ADS 会员分析链路
大数据·后端·apache hive
郑州光合科技余经理4 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
DianSan_ERP4 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
够快云库4 天前
能源行业非结构化数据治理实战:从数据沼泽到智能资产
大数据·人工智能·机器学习·企业文件安全
feifeigo1234 天前
matlab画图工具
开发语言·matlab
dustcell.4 天前
haproxy七层代理
java·开发语言·前端
norlan_jame4 天前
C-PHY与D-PHY差异
c语言·开发语言