ITPub博客

首页 > 应用开发 > Java > Scala的访问权限控制

Scala的访问权限控制

原创 Java 作者:541732025 时间:2015-11-24 21:16:58 0 删除 编辑
包、类、对象、成员的访问权限:

点击(此处)折叠或打开

  1. package spark{
  2.   package navigation{
  3.     private[spark] class Navigator{ //将Navigator的可见度扩展至spark,spark包下的所有包、类、对象都可以访问Navigator
  4.       protected[navigation] def useStarChart() {} //被protected修饰,可以被Navigator以及它的子类(类似于java),以及navigation下的所有内容访问
  5.       class LegOfJourney {
  6.         private[Navigator] val distance =100
  7.       }
  8.       private[this] var speed = 200 //只有本对象能访问,该类其它实例不能访问,类似于java中的private变量,而且没有getter方法
  9.     }
  10.   }
  11.   
  12.   package launch{
  13.     import navigation._ //因为launch与navigation平级,所以必须import
  14.     object Vehicle {
  15.       private[launch] val guide = new Navigator //因为launch是spark的子包。所以可以访问
  16.     }
  17.   }
  18. }

伴生类、伴生对象的访问权限:

点击(此处)折叠或打开

  1. class PackageOps_Advanced{
  2.   import PackageOps_Advanced.power
  3.   private def canMakeItTrue = power >10001 //伴生类可以访问伴生对象里面的所有内容
  4. }

  5. object PackageOps_Advanced{
  6.   private def power = 10000
  7.   
  8.   def makeItTrue(p : PackageOps_Advanced): Boolean = { //伴生对象可以访问伴生类的所有内容
  9.      val result = p.canMakeItTrue
  10.      result
  11.   }
  12. }

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/28912557/viewspace-1845817/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2013-05-23

  • 博文量
    127
  • 访问量
    479576