淺談Java內(nèi)部類——靜態(tài)內(nèi)部類
今天來說說Java中的最后一種內(nèi)部類——靜態(tài)內(nèi)部類
所謂的靜態(tài)內(nèi)部類,自然就是用static修飾的內(nèi)部類,那用static修飾過后的內(nèi)部類,跟一般的內(nèi)部類相比有什么特別的地方呢?
首先,它是靜態(tài)的,這就意味著它的創(chuàng)建不依賴于外部類,創(chuàng)建內(nèi)部類的實(shí)例不需要像普通內(nèi)部類一樣先創(chuàng)建外部類實(shí)例才能創(chuàng)建。
其次,有優(yōu)勢必然有劣勢,它不能像普通內(nèi)部類一樣無限制的訪問外部類的方法和成員變量,只能訪問靜態(tài)成員變量和靜態(tài)方法。
話不多說,先來看個(gè)栗子:
public class StaticInnerClass { //外部類的非靜態(tài)成員 private int numA = 1; //外部類的靜態(tài)成員 private static int numB = 2; //靜態(tài)內(nèi)部類 static class Inner { //內(nèi)部類的非靜態(tài)成員 private int numC = 3; //內(nèi)部類的靜態(tài)成員 private static int numD = 4; public void printInner(){ System.out.println('printInner'); System.out.println(numB);//訪問外部類的靜態(tài)成員 System.out.println(numC);//訪問內(nèi)部類的非靜態(tài)成員 System.out.println(numD);//訪問內(nèi)部類的靜態(tài)成員 } } //外部類的普通成員方法 public void printOuter(){ System.out.println('printOuter'); } public static void main(String[] args) { StaticInnerClass outer = new StaticInnerClass(); outer.printOuter(); Inner inner = new StaticInnerClass.Inner(); inner.printInner(); System.out.println(StaticInnerClass.numB); System.out.println(Inner.numD); }}
輸出如下:
printOuterprintInner23424
看起來,內(nèi)部類跟外部類的使用上是差不多的,更像是一個(gè)暫存在外部類中的一個(gè)類,跟外部類并沒有什么太多本質(zhì)上的聯(lián)系,但是創(chuàng)建的時(shí)候需要使用Outer.Inner的方式來定義,就像給類加了一個(gè)命名空間一樣。
再舉個(gè)栗子來看看靜態(tài)內(nèi)部類和非靜態(tài)內(nèi)部類的區(qū)別:(知乎上看到的一段話,覺得比喻比較形象)
如果把類比喻成雞蛋,內(nèi)部類為蛋,,外部類是蛋殼。那么靜態(tài)類相當(dāng)于熟雞蛋,就算蛋殼破碎(外部類沒有實(shí)例化),蛋黃依然完好(內(nèi)部類可以實(shí)例化);而非靜態(tài)類相當(dāng)于生雞蛋,蛋殼破碎(無實(shí)例化),蛋黃也會(huì)跟著xx(不能實(shí)例化)。
至于原因?其實(shí)就是因?yàn)榉庆o態(tài)內(nèi)部類中保存有外部類的指針,所以可以無限制訪問外部類的所有屬性,而靜態(tài)內(nèi)部類則沒有,所以靜態(tài)內(nèi)部類無法訪問外部類的非靜態(tài)成員和方法,僅僅是借用一下它的殼而已。
再來看一個(gè)栗子:
public class Caculate { //定義一個(gè)pair類來將兩個(gè)數(shù)捆綁 static class Pair{ private int first; private int second; public Pair(int first, int second) { this.first = first; this.second = second; } public int getFirst() { return first; } public int getSecond() { return second; } } //獲取一個(gè)int數(shù)組中的最大和最小值 public static Pair getMaxMin(int[] values){ int max = Integer.MIN_VALUE; int min = Integer.MAX_VALUE; for (int i:values){ if (min > i) min = i; if (max < i) max = i; } return new Pair(min,max); } public static void main(String[] args){ int[] list = {1,3,5,2,77,23,25}; Caculate.Pair pair = Caculate.getMaxMin(list); System.out.println(pair.getFirst()); System.out.println(pair.getSecond()); System.out.println(pair.first); System.out.println(pair.second); }}
這里getMaxMin里需要一次返回兩個(gè)值,所以用了一個(gè)Pair類來將兩個(gè)數(shù)捆綁到一起,而因?yàn)檫@個(gè)類只在Caculate類中使用,而且兩者并沒有依賴關(guān)系,所以這里使用靜態(tài)內(nèi)部類是最合適的。
靜態(tài)內(nèi)部類還有很多適用的場景,這就需要大家在今后的使用中慢慢體會(huì)了。
至此,本篇講解完畢,歡迎大家繼續(xù)關(guān)注。
以上就是淺談Java內(nèi)部類——靜態(tài)內(nèi)部類的詳細(xì)內(nèi)容,更多關(guān)于Java 靜態(tài)內(nèi)部類的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. jsp實(shí)現(xiàn)登錄驗(yàn)證的過濾器2. Xml簡介_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理3. phpstudy apache開啟ssi使用詳解4. ASP.NET MVC使用異步Action的方法5. 爬取今日頭條Ajax請求6. jsp文件下載功能實(shí)現(xiàn)代碼7. ajax實(shí)現(xiàn)頁面的局部加載8. AJAX的跨域問題解決方案9. uni-app結(jié)合.NET 7實(shí)現(xiàn)微信小程序訂閱消息推送10. 利用ajax+php實(shí)現(xiàn)商品價(jià)格計(jì)算
