Java中默認(rèn)的訪問權(quán)限作用域解析
Java默認(rèn)的訪問權(quán)限作用域
| 作用域 | 當(dāng)前類 | 同一包(package) | 子孫類 | 其他包 |
| public | Y | Y | Y | Y |
| protected | Y | Y | Y | N |
| default | Y | Y | N | N |
| private | Y | N | N | N |
1、要點(diǎn)
關(guān)于抽象類
JDK 1.8以前,抽象類的方法默認(rèn)訪問權(quán)限為protected
JDK 1.8時(shí),抽象類的方法默認(rèn)訪問權(quán)限變?yōu)閐efault
關(guān)于接口
JDK 1.8以前,接口中的方法必須是public的
JDK 1.8時(shí),接口中的方法可以是public的,也可以是default的
JDK 1.9時(shí),接口中的方法可以是private的
Java的訪問權(quán)限控制
今天我們來一起了解一下Java語言中的訪問權(quán)限控制。在討論訪問權(quán)限控制之前,先來討論一下為何需要訪問權(quán)限控制??紤]兩個(gè)場景:
場景1:工程師A編寫了一個(gè)類ClassA,但是工程師A并不希望ClassA被該應(yīng)用中其他所用的類都訪問到,那么該如何處理?
場景2:如果工程師A編寫了一個(gè)類ClassA,其中有兩個(gè)方法fun1、fun2,工程師只想讓fun1對外可見,也就是說,如果別的工程師來調(diào)用ClassA,只可以調(diào)用方法fun1,那么該怎么處理?
此時(shí),訪問權(quán)限控制便可以起到作用了。
在Java中,提供了四種訪問權(quán)限控制:默認(rèn)訪問權(quán)限(包訪問權(quán)限),public,private以及protected。
注意,上述四種訪問權(quán)限,只有默認(rèn)訪問權(quán)限和public能夠用來修飾類。修飾類的變量和方法四種權(quán)限都可以。(本處所說的類針對的是外部類,不包括內(nèi)部類)
下面就分別針對修飾類和修飾類的成員來講述這四種訪問權(quán)限控制。
1.修飾類
默認(rèn)訪問權(quán)限(包訪問權(quán)限):用來修飾類的話,表示該類只對同一個(gè)包中的其他類可見。
public:用來修飾類的話,表示該類對其他所有的類都可見。
下面通過幾個(gè)例子來看一下兩者的區(qū)別:
例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 { //默認(rèn)訪問權(quán)限(包訪問權(quán)限)
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類采用的是默認(rèn)訪問權(quán)限,而由于People類和Main類在同一個(gè)包中,因此People類對于Main類是可見的。
程序運(yùn)行結(jié)果:

例子2:
People.java
package com.cxh.test2;
class People { //默認(rèn)訪問權(quán)限(包訪問權(quán)限)
private String name = null;
public People(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
此時(shí)People類和Main類不在同一個(gè)包中,會(huì)發(fā)生什么情況呢?
下面是Main類中的提示的錯(cuò)誤:

提示Peolple類在Main類中不可視。從這里就可以看出,如果用默認(rèn)訪問權(quán)限去修飾一個(gè)類,該類只對同一個(gè)包中的其他類可見,對于不同包中的類是不可見的。
正如上圖的快速修正提示所示,將People類的默認(rèn)訪問權(quán)限更改為public的話,People類對于Main類便可見了。
2.修飾類的方法和變量
默認(rèn)訪問權(quán)限(包訪問權(quán)限):如果一個(gè)類的方法或變量被包訪問權(quán)限修飾,也就意味著只能在同一個(gè)包中的其他類中顯示地調(diào)用該類的方法或者變量,在不同包中的類中不能顯示地調(diào)用該類的方法或變量。
private:如果一個(gè)類的方法或者變量被private修飾,那么這個(gè)類的方法或者變量只能在該類本身中被訪問,在類外以及其他類中都不能顯示地進(jìn)行訪問。protected:如果一個(gè)類的方法或者變量被protected修飾,對于同一個(gè)包的類,這個(gè)類的方法或變量是可以被訪問的。對于不同包的類,只有繼承于該類的類才可以訪問到該類的方法或者變量。public:被public修飾的方法或者變量,在任何地方都是可見的。
下面再通過幾個(gè)例子來看一下它們作用域類的方法和變量時(shí)的區(qū)別:
例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() { //默認(rèn)訪問權(quán)限(包訪問權(quán)限)
return name;
}
void setName(String name) { //默認(rèn)訪問權(quán)限(包訪問權(quán)限)
this.name = name;
}
}
此時(shí)在Main類是可以顯示調(diào)用方法getName和setName的。
但是如果People類和Main類不在同一個(gè)包中:
package com.cxh.test2; //與Main類處于不同包中
public class People {
private String name = null;
public People(String name) {
this.name = name;
}
String getName() { //默認(rèn)訪問權(quán)限(包訪問權(quán)限)
return name;
}
void setName(String name) { //默認(rèn)訪問權(quán)限(包訪問權(quán)限)
this.name = name;
}
}
此時(shí)在Main類中會(huì)提示錯(cuò)誤:

由此可以看出,如果用默認(rèn)訪問權(quán)限來修飾類的方法或者變量,則只能在同一個(gè)包的其他類中進(jìn)行訪問。
例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;
}
}
此時(shí)是可以在Main中顯示調(diào)用方法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;
}
}
則會(huì)在Main中報(bào)錯(cuò):

如果在com.cxh.test1中定一個(gè)類Man繼承People,則可以在類Man中顯示調(diào)用方法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();
}
}
下面補(bǔ)充一些關(guān)于Java包和類文件的知識:
1)Java中的包主要是為了防止類文件命名沖突以及方便進(jìn)行代碼組織和管理;
2)對于一個(gè)Java源代碼文件,如果存在public類的話,只能有一個(gè)public類,且此時(shí)源代碼文件的名稱必須和public類的名稱完全相同,另外,如果還存在其他類,這些類在包外是不可見的。如果源代碼文件沒有public類,則源代碼文件的名稱可以隨意命名。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java常見基本數(shù)據(jù)結(jié)構(gòu)概覽
這篇文章主要介紹了Java常見的幾種基本數(shù)據(jù)結(jié)構(gòu),包括其含義和用法,,需要的朋友可以參考下2017-09-09
Retrofit+RxJava實(shí)現(xiàn)帶進(jìn)度條的文件下載
這篇文章主要為大家詳細(xì)介紹了Retrofit+RxJava實(shí)現(xiàn)帶進(jìn)度條的文件下載,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06
Spring?MVC請求轉(zhuǎn)發(fā)與請求重定向的示例詳解
轉(zhuǎn)發(fā)指服務(wù)器接收請求后,從一個(gè)資源跳轉(zhuǎn)到另一個(gè)資源中,請求轉(zhuǎn)發(fā)是一次請求,不會(huì)改變?yōu)g覽器的請求地址,這篇文章主要介紹了Spring?MVC請求轉(zhuǎn)發(fā)與請求重定向的相關(guān)知識,需要的朋友可以參考下2023-09-09
Springboot如何通過filter修改Header的值
這篇文章主要介紹了Springboot如何通過filter修改Header的值問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
解決Springboot集成Redis集群配置公網(wǎng)IP連接報(bào)私網(wǎng)IP連接失敗問題
在Springboot 集成 Redis集群配置公網(wǎng)IP連接報(bào)私網(wǎng)IP連接失敗,一直報(bào)私有IP連接失敗,所以本文小編給大家介紹了如何解決報(bào)錯(cuò)問題,如果有遇到相同問題的同學(xué),可以參考閱讀本文2023-10-10
在SpringBoot項(xiàng)目中實(shí)現(xiàn)讀寫分離的流程步驟
SpringBoot作為一種快速開發(fā)框架,廣泛應(yīng)用于Java項(xiàng)目中,在一些大型應(yīng)用中,數(shù)據(jù)庫的讀寫分離是提升性能和擴(kuò)展性的一種重要手段,本文將介紹如何在SpringBoot項(xiàng)目中優(yōu)雅地實(shí)現(xiàn)讀寫分離,并通過適當(dāng)?shù)拇a插入,詳細(xì)展開實(shí)現(xiàn)步驟,同時(shí)進(jìn)行拓展和分析2023-11-11
servlet之cookie簡介_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
Cookie技術(shù)誕生以來,它就成了廣大網(wǎng)絡(luò)用戶和Web開發(fā)人員爭論的一個(gè)焦點(diǎn)。下面這篇文章主要給大家介紹了關(guān)于servlet之cookie簡介的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。2017-07-07
一文詳解SpringBoot中CommandLineRunner接口
Spring Boot的CommandLineRunner接口是一個(gè)函數(shù)式接口,用于在Spring Boot應(yīng)用程序啟動(dòng)后執(zhí)行一些初始化操作,它提供了一個(gè)run方法,該方法在應(yīng)用程序啟動(dòng)后被調(diào)用,本文給大家詳細(xì)介紹了SpringBoot中CommandLineRunner接口,需要的朋友可以參考下2023-10-10

