Java访问控制权限
2014-07-27 22:50
225 查看
Java的访问控制权限相比于C++等语言可能稍微复杂一点,不过也不难理解。Java的访问控制权限分为两块——“类或接口的访问控制权限”与“变量和方法的访问控制权限”。
1.类或接口的访问控制权限(此处分析不包括内部类)
类或接口的访问控制权限是指能不能用该类建立对象,接口能不能被实现等等。能够修饰类或接口的访问控制权限的修饰符(modifier)只有两个——public和friendly.不过,值得一说的是friendly并不是Java的关键字,它只是一个习惯叫法,指的是“没有写访问控制权限修饰符”的情况。
public修饰的类或接口在同一个包中的任何一个类中都可以被访问。不同包呢?当然能访问啦,否则引包机制不就失效了嘛(因为引包相当于拿到了一个包的public类或接口)。
friendly修饰的类或接口在同一个包中的任何一个类中都可以被访问(和public相同),不能被不同包中的类访问。
总结:类或接口的访问控制权限分为“包中”和“包外”。无论修饰符(modifier)是什么,在“包中”均可访问。对于“包外”,public修饰的类或接口可以被访问,friendly修饰的类或接口不能被访问。
2.变量和方法的访问控制权限
变量和方法的访问控制权限的修饰符(modifier)有四个——public,protected,friendly和private.
变量和方法在本类(定义该变量或方法的类)中不论访问控制权限修饰符是什么,均可被访问(这里先不考虑“静态”的情况)。那么接下来只研究类外。类外也分“包内”和“包外”,接下来就从这两方面说起,并且研究“包外”时只考虑引入的包中的public类,因为friendly的类连直接被访问都做不到,何谈访问变量和方法。
public修饰的变量和方法在“包内”和“包外”均可被访问。
protected修饰的变量和方法在“包内”可以被访问,在“包外”只能被子类访问。
friendly修饰的变量和方法在“包内”可以被访问,在“包外”不能被访问。
private修饰的变量和方法在“包内”或“包外”均不能被访问。
总结:对于“类外”,public,protected,friendly和private的严格性逐渐递增。public可以说没限制,protected剥夺了“包外”非子类的访问能力,friendly在protected基础上进一步剥夺了“包外”子类的访问能力,至此“包外”的访问能力全无;private更严格,它在friendly基础上更是一下剥夺了“包内”的访问能力。
总的来说,看某个成员能否被访问要分两步:1.根据所在类的访问控制权限看该类能否被访问;2.根据该成员的访问控制权限判断取得所在类后该成员能否被访问。
1.类或接口的访问控制权限(此处分析不包括内部类)
类或接口的访问控制权限是指能不能用该类建立对象,接口能不能被实现等等。能够修饰类或接口的访问控制权限的修饰符(modifier)只有两个——public和friendly.不过,值得一说的是friendly并不是Java的关键字,它只是一个习惯叫法,指的是“没有写访问控制权限修饰符”的情况。
public修饰的类或接口在同一个包中的任何一个类中都可以被访问。不同包呢?当然能访问啦,否则引包机制不就失效了嘛(因为引包相当于拿到了一个包的public类或接口)。
friendly修饰的类或接口在同一个包中的任何一个类中都可以被访问(和public相同),不能被不同包中的类访问。
总结:类或接口的访问控制权限分为“包中”和“包外”。无论修饰符(modifier)是什么,在“包中”均可访问。对于“包外”,public修饰的类或接口可以被访问,friendly修饰的类或接口不能被访问。
2.变量和方法的访问控制权限
变量和方法的访问控制权限的修饰符(modifier)有四个——public,protected,friendly和private.
变量和方法在本类(定义该变量或方法的类)中不论访问控制权限修饰符是什么,均可被访问(这里先不考虑“静态”的情况)。那么接下来只研究类外。类外也分“包内”和“包外”,接下来就从这两方面说起,并且研究“包外”时只考虑引入的包中的public类,因为friendly的类连直接被访问都做不到,何谈访问变量和方法。
public修饰的变量和方法在“包内”和“包外”均可被访问。
protected修饰的变量和方法在“包内”可以被访问,在“包外”只能被子类访问。
friendly修饰的变量和方法在“包内”可以被访问,在“包外”不能被访问。
private修饰的变量和方法在“包内”或“包外”均不能被访问。
总结:对于“类外”,public,protected,friendly和private的严格性逐渐递增。public可以说没限制,protected剥夺了“包外”非子类的访问能力,friendly在protected基础上进一步剥夺了“包外”子类的访问能力,至此“包外”的访问能力全无;private更严格,它在friendly基础上更是一下剥夺了“包内”的访问能力。
总的来说,看某个成员能否被访问要分两步:1.根据所在类的访问控制权限看该类能否被访问;2.根据该成员的访问控制权限判断取得所在类后该成员能否被访问。
相关文章推荐
- java--访问控制和内部类 (权限修饰符)
- java学习笔记八——访问权限控制
- 关于java访问权限控制的误区
- java 核心技术 卷1 第三章 InputTest &&权限访问控制
- 【Java】第6章 访问权限控制
- 从0开始学java-访问权限控制
- java的访问权限控制--疑问
- JAVA 权限访问控制
- Java程序访问权限控制(policy文件)
- java访问权限的控制
- Java初级--访问控制权限及多线程
- thinking in java笔记 6 访问权限控制
- java编程思想阅读笔记(二)访问权限控制和复用类
- java访问权限控制符
- 12.16(Java 访问权限控制, ClassPath,ibatis调试心得)
- JavaWeb 案例——访问权限控制
- 访问控制权限和 ------java命名规范
- Java中的四种访问权限控制
- JAVA访问权限控制
- Java 编程思想(第四版)学习笔记(6)访问权限控制