作用域简介
Java中有四种定义作用域或者说访问权限的关键字,分别为public,protected,(default)以及private,作用域的级别和范围从高到低。
| 作用域 | 类内部 | 本包 | 子类 | 外部包 |
|---|---|---|---|---|
| public | √ | √ | √ | √ |
| protected | √ | √ | √ | × |
| (default) | √ | √ | × | × |
| private | √ | × | × | × |
注意:Java的访问控制是停留在编译层的,也就是它不会在.class文件中留下任何的痕迹,只在编译的时候进行访问控制的检查。其实,通过反射的手段,是可以访问任何包下任何类中的成员,例如,访问类的私有成员也是可能的。
公共权限 public
public可以修饰类,数据成员,构造方法,方法成员。被public修饰的成员 ,可以在任何一个类中被调用,不管同包或不同包,是权限最大的一个修饰符。 它往往用于对外的情况,也就是对象或类对外的一种接口的形式。
受保护权限protected
protected可以修饰数据成员,构造方法,方法成员,不能修饰类(此处指外部类,不考虑内部类)。被protected修饰的成员,能在定义它们的类中,同包的类中被调用。如果有不同包的类想调用它们,那么这个类必须是定义它们的类的子类。
默认权限 (default)
类,数据成员,构造方法,方法成员,都能够使用默认权限,即不写任何关键字。默认权限即同包权限,同包权限的元素只能在定义它们的类中,以及同包的类中被调用。
私有权限 private
private可以修饰数据成员,构造方法,方法成员,不能修饰类(此处指外部类,不考虑内部类)。被private修饰的成员,只能在定义它们的类中使用,在其他类中不能调用。
使用注意
1.并不是每个关键字都可以修饰类(指外部类),只有public和default可 以。
2.所有关键字都可以修饰数据成员,方法成员,构造方法。
3.为了代码安全起见,关键字不要尽量使用权限大的,而是适用即可。比如 ,数据成员,如果没有特殊需要,尽可能用private。
4.关键字修饰的是“被访问”的权限。
结束语:本文仅用来学习记录,参考查阅。
本文介绍了Java中的四种作用域关键字:public、protected、default及private,详细解释了它们的权限级别和适用范围,并提供了使用建议。
2653

被折叠的 条评论
为什么被折叠?



