這篇文章主要講解了“java的四種訪問(wèn)權(quán)限實(shí)例分析”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“java的四種訪問(wèn)權(quán)限實(shí)例分析”吧!
因?yàn)榕驼嬲\(chéng),有更多的客戶和我們聚集在一起,為了共同目標(biāo),創(chuàng)新互聯(lián)公司在工作上密切配合,從創(chuàng)業(yè)型企業(yè)到如今不斷成長(zhǎng),要感謝客戶對(duì)我們的高要求,讓我們敢于面對(duì)挑戰(zhàn),才有今天的進(jìn)步與發(fā)展。從網(wǎng)站到微信小程序開發(fā),軟件開發(fā),手機(jī)APP定制開發(fā),十多年企業(yè)網(wǎng)站建設(shè)服務(wù)經(jīng)驗(yàn),為企業(yè)提供網(wǎng)站設(shè)計(jì),網(wǎng)站托管、服務(wù)器托管一條龍服務(wù).為企業(yè)提供全網(wǎng)整合營(yíng)銷推廣,按需制作網(wǎng)站,原創(chuàng)設(shè)計(jì),十多年品質(zhì),值得您的信賴.
一、訪問(wèn)權(quán)限簡(jiǎn)介
訪問(wèn)權(quán)限控制: 指的是本類及本類內(nèi)部的成員(成員變量、成員方法、內(nèi)部類)對(duì)其他類的可見性,即這些內(nèi)容是否允許其他類訪問(wèn)。
Java 中一共有四種訪問(wèn)權(quán)限控制,其權(quán)限控制的大小情況是這樣的:public > protected > default(包訪問(wèn)權(quán)限) > private ,具體的權(quán)限控制看下面表格,列所指定的類是否有權(quán)限允許訪問(wèn)行的權(quán)限控制下的內(nèi)容:
public 是 是 是 是 protected 是 是 是 否 default 是 是 否 否 private 是 否 否 否
1、public: 所修飾的類、變量、方法,在內(nèi)外包均具有訪問(wèn)權(quán)限;
2、protected: 這種權(quán)限是為繼承而設(shè)計(jì)的,protected所修飾的成員,對(duì)所有子類是可訪問(wèn)的,但只對(duì)同包的類是可訪問(wèn)的,對(duì)外包的非子類是不可以訪問(wèn);
3、包訪問(wèn)權(quán)限(default): 只對(duì)同包的類具有訪問(wèn)的權(quán)限,外包的所有類都不能訪問(wèn);
4、private: 私有的權(quán)限,只對(duì)本類的方法可以使用;
注意: 要區(qū)分開 protected 權(quán)限、包訪問(wèn)權(quán)限,正確使用它們;
當(dāng)某個(gè)成員能被所有的子類繼承,但不能被外包的非子類訪問(wèn),就是用protected; 當(dāng)某個(gè)成員的訪問(wèn)權(quán)限只對(duì)同包的類開放,包括不能讓外包的類繼承這個(gè)成員,就用包訪問(wèn)權(quán)限;
使用訪問(wèn)權(quán)限控制的原因:
1)使用戶不要碰觸那些他們不該碰觸的部分;2)類庫(kù)設(shè)計(jì)者可以更改類的內(nèi)部工作的方式,而不會(huì)擔(dān)心這樣會(huì)對(duì)用戶產(chǎn)生重大影響;
二、訪問(wèn)權(quán)限控制的使用場(chǎng)景
訪問(wèn)權(quán)限使用的場(chǎng)景可以總結(jié)為下面的五種場(chǎng)景,分別對(duì)訪問(wèn)權(quán)限的使用有不同的限制:
1. 外部類的訪問(wèn)控制
外部類(外部接口) 是相對(duì)于內(nèi)部類(也稱為嵌套類)、內(nèi)部接口而言的。外部類的訪問(wèn)控制只能是這兩種:public 、default 。
//public 訪問(wèn)呢權(quán)限的外部類,所有類都可以使用這個(gè)類public class OuterClass {}//default 權(quán)限的外部接口,所有類、接口均可以使用此接口interface OuterInterface{ }
2. 類里面的成員的訪問(wèn)控制
類里面的成員分為三類 : 成員變量、成員方法、成員內(nèi)部類(內(nèi)部接口)
類里面的成員的訪問(wèn)控制可以是四種,也就是可以使用所有的訪問(wèn)控制權(quán)限
public class OuterClass { public int aa; //可以被所有的類訪問(wèn) protected boolean bb; //可以被所有子類以及本包的類使用 void cc() { //default 訪問(wèn)權(quán)限,能在本包范圍內(nèi)使用 System.out.println("包訪問(wèn)權(quán)限"); } //private權(quán)限的內(nèi)部類,即這是私有的內(nèi)部類,只能在本類使用 private class InnerClass{ }}
訪問(wèn)權(quán)限 | 本類 | 本包的類 | 子類 | 非子類的外包類 |
---|
注意:
這里的類里面的成員 是指類的全局成員,并沒有包括局部的成員(局部變量、局部?jī)?nèi)部類,沒有局部?jī)?nèi)部接口)?;蛘哒f(shuō),局部成員是沒有訪問(wèn)權(quán)限控制的,因?yàn)榫植砍蓡T只在其所在的作用域內(nèi)起作用,不可能被其他類訪問(wèn)到。
public void count(){ //局部成員變量 public int amount;//編譯無(wú)法通過(guò),不能用public修飾 int money;//編譯通過(guò) //局部嵌套接口 class customer{//編譯通過(guò) }}
上面的兩種場(chǎng)景幾乎可以適應(yīng)所有的情況,但有一些情況比較特殊,還做了有些額外訪問(wèn)權(quán)限的要求
3. 抽象方法的訪問(wèn)權(quán)限
普通方法是可以使用四種訪問(wèn)權(quán)限的,但抽象方法是有一個(gè)限制:不能用private 來(lái)修飾,也即抽象方法不能是私有的,否則,子類就無(wú)法繼承實(shí)現(xiàn)抽象方法。
4. 接口成員的訪問(wèn)權(quán)限
接口由于其的特殊性,所有成員的訪問(wèn)權(quán)限都規(guī)定得死死的,下面是接口成員的訪問(wèn)權(quán)限:
變量: public static final 抽象方法: public abstract 靜態(tài)方法: public static,JDK1.8后才支持 內(nèi)部類、內(nèi)部接口 : public static
也因?yàn)樗械囊磺卸寄J(rèn)強(qiáng)制規(guī)定好了,所以我們?cè)谟玫臅r(shí)候,并不一定需要完整寫出所有的修飾符,編譯器會(huì)幫我們完成的,也就是,可以少寫修飾符,但不能寫錯(cuò)修飾符。
public interface Interface_Test { public int aa = 6; //少寫了 static final int bb = 5; // //嵌套接口,可以不寫public static interface cc{ }}
5. 構(gòu)造器的訪問(wèn)權(quán)限
構(gòu)造器的訪問(wèn)權(quán)限可以是以上四種權(quán)限中的任意一種:
1、采用 private:一般是不允許直接構(gòu)造這個(gè)類的對(duì)象,再結(jié)合工廠方法(static方法),實(shí)現(xiàn)單例模式。注意:所有子類都不能繼承它。
2、采用包訪問(wèn)控制:比較少用,這個(gè)類的對(duì)象只能在本包中使用,但是如果這個(gè)類有static 成員,那么這個(gè)類還是可以在外包使用;(也許可以用于該類的外包單例模式)。
注意:外包的類不能繼承這個(gè)類;
3、采用 protected :就是為了能讓所有子類繼承這個(gè)類,但是外包的非子類不能訪問(wèn)這個(gè)類;
4、采用 public :對(duì)于內(nèi)外包的所有類都是可訪問(wèn)的;
注意: 構(gòu)造方法有點(diǎn)特殊,因?yàn)樽宇惖臉?gòu)造器初始化時(shí),都要調(diào)用父類的構(gòu)造器,所以一旦父類構(gòu)造器不能被訪問(wèn),那么子類的構(gòu)造器調(diào)用失敗,意味子類繼承父類失?。?/p>
感謝各位的閱讀,以上就是“java的四種訪問(wèn)權(quán)限實(shí)例分析”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)java的四種訪問(wèn)權(quán)限實(shí)例分析這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!