引言
谷城網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),谷城網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為谷城上千余家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站制作要多少錢,請找那個售后服務(wù)好的谷城做網(wǎng)站的公司定做!
Java中的訪問權(quán)限理解起來不難,但完全掌握卻不容易,特別是4種訪問權(quán)限并不是任何時候都可以使用。下面整理一下,在什么情況下,有哪些訪問權(quán)限可以允許選擇。
一、訪問權(quán)限簡介
訪問權(quán)限控制: 指的是本類及本類內(nèi)部的成員(成員變量、成員方法、內(nèi)部類)對其他類的可見性,即這些內(nèi)容是否允許其他類訪問。
Java 中一共有四種訪問權(quán)限控制,其權(quán)限控制的大小情況是這樣的:public > protected > default(包訪問權(quán)限) > private ,具體的權(quán)限控制看下面表格,列所指定的類是否有權(quán)限允許訪問行的權(quán)限控制下的內(nèi)容:
訪問權(quán)限 | 本類 | 本包的類 | 子類 | 非子類的外包類 |
---|---|---|---|---|
public | 是 | 是 | 是 | 是 |
protected | 是 | 是 | 是 | 否 |
default | 是 | 是 | 否 | 否 |
private | 是 | 否 | 否 | 否 |
1、public: 所修飾的類、變量、方法,在內(nèi)外包均具有訪問權(quán)限;
2、protected: 這種權(quán)限是為繼承而設(shè)計的,protected所修飾的成員,對所有子類是可訪問的,但只對同包的類是可訪問的,對外包的非子類是不可以訪問;
3、包訪問權(quán)限(default): 只對同包的類具有訪問的權(quán)限,外包的所有類都不能訪問;
4、private: 私有的權(quán)限,只對本類的方法可以使用;
注意: 要區(qū)分開 protected 權(quán)限、包訪問權(quán)限,正確使用它們;
使用訪問權(quán)限控制的原因:
1)使用戶不要碰觸那些他們不該碰觸的部分;
2)類庫設(shè)計者可以更改類的內(nèi)部工作的方式,而不會擔(dān)心這樣會對用戶產(chǎn)生重大影響;
二、訪問權(quán)限控制的使用場景
訪問權(quán)限使用的場景可以總結(jié)為下面的五種場景,分別對訪問權(quán)限的使用有不同的限制:
1. 外部類的訪問控制
外部類(外部接口) 是相對于內(nèi)部類(也稱為嵌套類)、內(nèi)部接口而言的。外部類的訪問控制只能是這兩種:public 、default 。
//public 訪問呢權(quán)限的外部類,所有類都可以使用這個類 public class OuterClass { } //default 權(quán)限的外部接口,所有類、接口均可以使用此接口 interface OuterInterface{ }
2. 類里面的成員的訪問控制
類里面的成員分為三類 : 成員變量、成員方法、成員內(nèi)部類(內(nèi)部接口)
類里面的成員的訪問控制可以是四種,也就是可以使用所有的訪問控制權(quán)限
public class OuterClass { public int aa; //可以被所有的類訪問 protected boolean bb; //可以被所有子類以及本包的類使用 void cc() { //default 訪問權(quán)限,能在本包范圍內(nèi)使用 System.out.println("包訪問權(quán)限"); } //private權(quán)限的內(nèi)部類,即這是私有的內(nèi)部類,只能在本類使用 private class InnerClass{ } }
注意:
這里的類里面的成員 是指類的全局成員,并沒有包括局部的成員(局部變量、局部內(nèi)部類,沒有局部內(nèi)部接口)。或者說,局部成員是沒有訪問權(quán)限控制的,因為局部成員只在其所在的作用域內(nèi)起作用,不可能被其他類訪問到。
public void count(){ //局部成員變量 public int amount;//編譯無法通過,不能用public修飾 int money;//編譯通過 //局部嵌套接口 class customer{//編譯通過 } }
上面的兩種場景幾乎可以適應(yīng)所有的情況,但有一些情況比較特殊,還做了有些額外訪問權(quán)限的要求
3. 抽象方法的訪問權(quán)限
普通方法是可以使用四種訪問權(quán)限的,但抽象方法是有一個限制:不能用private 來修飾,也即抽象方法不能是私有的,否則,子類就無法繼承實現(xiàn)抽象方法。
4. 接口成員的訪問權(quán)限
接口由于其的特殊性,所有成員的訪問權(quán)限都規(guī)定得死死的,下面是接口成員的訪問權(quán)限:
也因為所有的一切都默認(rèn)強(qiáng)制規(guī)定好了,所以我們在用的時候,并不一定需要完整寫出所有的修飾符,編譯器會幫我們完成的,也就是,可以少寫修飾符,但不能寫錯修飾符。
public interface Interface_Test { public int aa = 6; //少寫了 static final int bb = 5; // //嵌套接口,可以不寫public static interface cc{ } }
5. 構(gòu)造器的訪問權(quán)限
構(gòu)造器的訪問權(quán)限可以是以上四種權(quán)限中的任意一種:
1、采用 private:一般是不允許直接構(gòu)造這個類的對象,再結(jié)合工廠方法(static方法),實現(xiàn)單例模式。注意:所有子類都不能繼承它。
2、采用包訪問控制:比較少用,這個類的對象只能在本包中使用,但是如果這個類有static 成員,那么這個類還是可以在外包使用;(也許可以用于該類的外包單例模式)。
注意:外包的類不能繼承這個類;
3、采用 protected :就是為了能讓所有子類繼承這個類,但是外包的非子類不能訪問這個類;
4、采用 public :對于內(nèi)外包的所有類都是可訪問的;
注意: 構(gòu)造方法有點特殊,因為子類的構(gòu)造器初始化時,都要調(diào)用父類的構(gòu)造器,所以一旦父類構(gòu)造器不能被訪問,那么子類的構(gòu)造器調(diào)用失敗,意味子類繼承父類失?。?/p>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。