java的四种访问权限实例分析-创新互联-成都创新互联网站建设

关于创新互联

多方位宣传企业产品与服务 突出企业形象

公司简介 公司的服务 荣誉资质 新闻动态 联系我们

java的四种访问权限实例分析-创新互联

这篇文章主要讲解了“java的四种访问权限实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“java的四种访问权限实例分析”吧!

成都创新互联是一家专业提供民丰企业网站建设,专注与成都做网站、网站制作、HTML5、小程序制作等业务。10年已为民丰众多企业、政府机构等服务。创新互联专业网站设计公司优惠进行中。

一、访问权限简介

访问权限控制: 指的是本类及本类内部的成员(成员变量、成员方法、内部类)对其他类的可见性,即这些内容是否允许其他类访问。

Java 中一共有四种访问权限控制,其权限控制的大小情况是这样的:public > protected > default(包访问权限) > private ,具体的权限控制看下面表格,列所指定的类是否有权限允许访问行的权限控制下的内容:

public      是      是      是      是              protected      是      是      是      否              default      是      是      否      否              private      是      否      否      否

1、public: 所修饰的类、变量、方法,在内外包均具有访问权限;

2、protected: 这种权限是为继承而设计的,protected所修饰的成员,对所有子类是可访问的,但只对同包的类是可访问的,对外包的非子类是不可以访问;

3、包访问权限(default): 只对同包的类具有访问的权限,外包的所有类都不能访问;

4、private: 私有的权限,只对本类的方法可以使用;

注意: 要区分开 protected 权限、包访问权限,正确使用它们;

当某个成员能被所有的子类继承,但不能被外包的非子类访问,就是用protected;  当某个成员的访问权限只对同包的类开放,包括不能让外包的类继承这个成员,就用包访问权限;

使用访问权限控制的原因:

1)使用户不要碰触那些他们不该碰触的部分;2)类库设计者可以更改类的内部工作的方式,而不会担心这样会对用户产生重大影响;

二、访问权限控制的使用场景

访问权限使用的场景可以总结为下面的五种场景,分别对访问权限的使用有不同的限制:

1. 外部类的访问控制

外部类(外部接口) 是相对于内部类(也称为嵌套类)、内部接口而言的。外部类的访问控制只能是这两种:public 、default 。

//public 访问呢权限的外部类,所有类都可以使用这个类public class OuterClass {}//default 权限的外部接口,所有类、接口均可以使用此接口interface OuterInterface{ }

2. 类里面的成员的访问控制

类里面的成员分为三类 : 成员变量、成员方法、成员内部类(内部接口)

类里面的成员的访问控制可以是四种,也就是可以使用所有的访问控制权限

public class OuterClass {  public int aa; //可以被所有的类访问  protected boolean bb; //可以被所有子类以及本包的类使用   void cc() { //default 访问权限,能在本包范围内使用    System.out.println("包访问权限");  }    //private权限的内部类,即这是私有的内部类,只能在本类使用  private class InnerClass{      }}

访问权限本类本包的类子类非子类的外包类

注意:

这里的类里面的成员 是指类的全局成员,并没有包括局部的成员(局部变量、局部内部类,没有局部内部接口)。或者说,局部成员是没有访问权限控制的,因为局部成员只在其所在的作用域内起作用,不可能被其他类访问到。

public void count(){  //局部成员变量  public int amount;//编译无法通过,不能用public修饰  int money;//编译通过  //局部嵌套接口  class customer{//编译通过  }}

上面的两种场景几乎可以适应所有的情况,但有一些情况比较特殊,还做了有些额外访问权限的要求

3. 抽象方法的访问权限

普通方法是可以使用四种访问权限的,但抽象方法是有一个限制:不能用private 来修饰,也即抽象方法不能是私有的,否则,子类就无法继承实现抽象方法。

4. 接口成员的访问权限

接口由于其的特殊性,所有成员的访问权限都规定得死死的,下面是接口成员的访问权限:

变量: public static final  抽象方法: public abstract  静态方法: public static,JDK1.8后才支持  内部类、内部接口 : public static

也因为所有的一切都默认强制规定好了,所以我们在用的时候,并不一定需要完整写出所有的修饰符,编译器会帮我们完成的,也就是,可以少写修饰符,但不能写错修饰符。

public interface Interface_Test {    public int aa = 6; //少写了 static final   int bb = 5; //    //嵌套接口,可以不写public static   interface cc{      }}

5. 构造器的访问权限

构造器的访问权限可以是以上四种权限中的任意一种:

1、采用 private:一般是不允许直接构造这个类的对象,再结合工厂方法(static方法),实现单例模式。注意:所有子类都不能继承它。

2、采用包访问控制:比较少用,这个类的对象只能在本包中使用,但是如果这个类有static 成员,那么这个类还是可以在外包使用;(也许可以用于该类的外包单例模式)。

注意:外包的类不能继承这个类;

3、采用 protected :就是为了能让所有子类继承这个类,但是外包的非子类不能访问这个类;

4、采用 public :对于内外包的所有类都是可访问的;

注意: 构造方法有点特殊,因为子类的构造器初始化时,都要调用父类的构造器,所以一旦父类构造器不能被访问,那么子类的构造器调用失败,意味子类继承父类失败!

感谢各位的阅读,以上就是“java的四种访问权限实例分析”的内容了,经过本文的学习后,相信大家对java的四种访问权限实例分析这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联网站建设公司,,小编将为大家推送更多相关知识点的文章,欢迎关注!


新闻标题:java的四种访问权限实例分析-创新互联
网址分享:http://kswsj.cn/article/ccesej.html

其他资讯