今天我们来一起了解一下Java语言中的访问权限控制。在讨论访问权限控制之前,先来讨论一下为何需要访问权限控制。考虑两个场景:
场景1:工程师A编写了一个类ClassA,但是工程师A并不希望ClassA被该应用中其他所用的类都访问到,那么该如何处理?
场景2:如果工程师A编写了一个类ClassA,其中有两个方法fun1、fun2,工程师只想让fun1对外可见,也就是说,如果别的工程师来调用ClassA,只可以调用方法fun1,那么该怎么处理?
此时,访问权限控制便可以起到作用了。
在Java中,提供了四种访问权限控制:默认访问权限(包访问权限),public,private以及protected。
注意,上述四种访问权限,只有默认访问权限和public能够用来修饰类。修饰类的变量和方法四种权限都可以。(本处所说的类针对的是外部类,不包括内部类)
下面就分别针对修饰类和修饰类的成员来讲述这四种访问权限控制。
1.修饰类
默认访问权限(包访问权限):用来修饰类的话,表示该类只对同一个包中的其他类可见。
public:用来修饰类的话,表示该类对其他所有的类都可见。
下面通过几个例子来看一下两者的区别:
例1:
Main.java:
package com.cxh.test1; public class Main { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub People people = new People("Tom"); System.out.println(people.getName()); } }
People.java
package com.cxh.test1; class People { //默认访问权限(包访问权限) private String name = null; public People(String name) { this.name = name; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
从代码可以看出,修饰People类采用的是默认访问权限,而由于People类和Main类在同一个包中,因此People类对于Main类是可见的。
程序运行结果:
例子2:
People.java
package com.cxh.test2; class People { //默认访问权限(包访问权限) private String name = null; public People(String name) { this.name = name; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
此时People类和Main类不在同一个包中,会发生什么情况呢?
下面是Main类中的提示的错误:
提示Peolple类在Main类中不可视。从这里就可以看出,如果用默认访问权限去修饰一个类,该类只对同一个包中的其他类可见,对于不同包中的类是不可见的。
正如上图的快速修正提示所示,将People类的默认访问权限更改为public的话,People类对于Main类便可见了。
2.修饰类的方法和变量
默认访问权限(包访问权限):如果一个类的方法或变量被包访问权限修饰,也就意味着只能在同一个包中的其他类中显示地调用该类的方法或者变量,在不同包中的类中不能显示地调用该类的方法或变量。
private:如果一个类的方法或者变量被private修饰,那么这个类的方法或者变量只能在该类本身中被访问,在类外以及其他类中都不能显示地进行访问。
protected:如果一个类的方法或者变量被protected修饰,对于同一个包的类,这个类的方法或变量是可以被访问的。对于不同包的类,只有继承于该类的类才可以访问到该类的方法或者变量。
public:被public修饰的方法或者变量,在任何地方都是可见的。
下面再通过几个例子来看一下它们作用域类的方法和变量时的区别:
例3:
Main.java没有变化
People.java
package com.cxh.test1; public class People { private String name = null; public People(String name) { this.name = name; } String getName() { //默认访问权限(包访问权限) return name; } void setName(String name) { //默认访问权限(包访问权限) this.name = name; } }
此时在Main类是可以显示调用方法getName和setName的。
但是如果People类和Main类不在同一个包中:
package com.cxh.test2; //与Main类处于不同包中 public class People { private String name = null; public People(String name) { this.name = name; } String getName() { //默认访问权限(包访问权限) return name; } void setName(String name) { //默认访问权限(包访问权限) this.name = name; } }
此时在Main类中会提示错误:
由此可以看出,如果用默认访问权限来修饰类的方法或者变量,则只能在同一个包的其他类中进行访问。
例4:
People.java
package com.cxh.test1; public class People { private String name = null; public People(String name) { this.name = name; } protected String getName() { return name; } protected void setName(String name) { this.name = name; } }
此时是可以在Main中显示调用方法getName和setName的。
如果People类和Main类处于不同包中:
package com.cxh.test2; public class People { private String name = null; public People(String name) { this.name = name; } protected String getName() { return name; } protected void setName(String name) { this.name = name; } }
则会在Main中报错:
如果在com.cxh.test1中定一个类Man继承People,则可以在类Man中显示调用方法getName和setName:
package com.cxh.test1; import com.cxh.test2.People; public class Man extends People{ public Man(String name){ super(name); } public String toString() { return getName(); } }
下面补充一些关于Java包和类文件的知识:
1)Java中的包主要是为了防止类文件命名冲突以及方便进行代码组织和管理;
2)对于一个Java源代码文件,如果存在public类的话,只能有一个public类,且此时源代码文件的名称必须和public类的名称完全相同,另外,如果还存在其他类,这些类在包外是不可见的。如果源代码文件没有public类,则源代码文件的名称可以随意命名。
以上就是本文的全部内容,希望对大家的学习有所帮助。
本文向大家介绍详解Java之路(五) 访问权限控制,包括了详解Java之路(五) 访问权限控制的使用技巧和注意事项,需要的朋友参考一下 在Java中,所有事物都具有某种形式的访问权限控制。 访问权限的控制等级从最大到最小依次为:public,protected,包访问权限(无关键词)和private。 public,protected和private这几个Java访问权限修饰词在使用时,是置于类中
本文向大家介绍java类访问权限与成员访问权限解析,包括了java类访问权限与成员访问权限解析的使用技巧和注意事项,需要的朋友参考一下 在写代码的时候有个问题:包内定义了一个接口类,另外一个包要实现它,这里采用接口隔离与依赖倒置原则,将两个包的依赖关系倒置过来。但是,这里就遇到了一个问题,实现类采用工厂模式来实例化,所以实现类就不想暴露给包外,但是实现类还要实现public接口。所以这里有产生了一
本文向大家介绍Java编程访问权限的控制代码详解,包括了Java编程访问权限的控制代码详解的使用技巧和注意事项,需要的朋友参考一下 本文研究的主要是Java编程访问权限的控制的相关内容,具体介绍如下。 之前没去注意的修饰符,一般变量前面没添加,一个是不知道有什么用,一个是懒,后面遇到项目的时候就会发现私有和公有区别还是很大的。 (1)首先是包名 使用一个类的时候,例如集合类,就需要引入这个包,然后
主要内容:开启 ACL 权限Linux 系统传统的权限控制方式,无非是利用 3 种身份(文件所有者,所属群组,其他用户),并分别搭配 3 种权限(读 r,写 w,访问 x)。比如,我们可以通过 ls -l 命令查看当前目录中所有文件的详细信息,其中就包含对各文件的权限设置: [root@localhost ~]# ls -l total 36 drwxr-xr-x. 2 root root 4096 Apr 15 16:33
本文向大家介绍Java访问权限原理与用法详解,包括了Java访问权限原理与用法详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Java访问权限原理与用法。分享给大家供大家参考,具体如下: 构造者模式思想 进行初始化,解决了多个构造器重载,构造器参数过多记不住的情况。 包 层次结构 package 父包[.子包.······]; 包名:小写字母;通常是域名反转.部门名.项目名 包的好处
本文向大家介绍Java访问权限控制的重要性深入讲解,包括了Java访问权限控制的重要性深入讲解的使用技巧和注意事项,需要的朋友参考一下 前言 人在什么面前最容易失去抵抗力? 美色,算是一个,比如说西施的贡献薄就是忍辱负重、以身报国、助越灭吴;金钱,算是另外一个,我们古人常说“钱乃身外之物,生不带来死不带去”,但我们又都知道“有钱能使鬼推磨”。 除去美色和金钱,我认为还有一个,就是读者的认可——“二