java中staticclass靜態(tài)類詳解
一般情況下是不可以用static修飾類的。如果一定要用static修飾類的話,通常static修飾的是匿名內部類。
在一個類中創(chuàng)建另外一個類,叫做成員內部類。這個成員內部類可以靜態(tài)的(利用static關鍵字修飾),也可以是非靜態(tài)的。由于靜態(tài)的內部類在定義、使用的時候會有種種的限制。所以在實際工作中用到的并不多。
在開發(fā)過程中,內部類中使用的最多的還是非靜態(tài)地成員內部類。不過在特定的情況下,靜態(tài)內部類也能夠發(fā)揮其獨特的作用。
一、靜態(tài)內部類的使用目的。
在定義內部類的時候,可以在其前面加上一個權限修飾符static。此時這個內部類就變?yōu)榱遂o態(tài)內部類。不過由于種種的原因,如使用上的限制等等因素(具體的使用限制,筆者在下面的內容中會詳細闡述),在實際工作中用的并不是很多。但是并不是說其沒有價值。在某些特殊的情況下,少了這個靜態(tài)內部類還真是不行。如在進行代碼程序測試的時候,如果在每一個Java源文件中都設置一個主方法(主方法是某個應用程序的入口,必須具有),那么會出現(xiàn)很多額外的代碼。而且最主要的時這段主程序的代碼對于Java文件來說,只是一個形式,其本身并不需要這種主方法。但是少了這個主方法又是萬萬不行的。在這種情況下,就可以將主方法寫入到靜態(tài)內部類中,從而不用為每個Java源文件都設置一個類似的主方法。這對于代碼測試是非常有用的。在一些中大型的應用程序開發(fā)中,則是一個常用的技術手段。為此,這個靜態(tài)內部類雖然不怎么常用,但是程序開發(fā)人員還必須要掌握它。也許在某個關鍵的時刻,其還可以發(fā)揮巨大的作用也說不定。
public class MainInStaticClass {
static class Main{
static void main() {
//將主方法寫到靜態(tài)內部類中,從而不必為每個源文件都這種一個類似的主方法
new MainInStaticClass().print();
}
}
public static void main(String[] args){
new MainInStaticClass().print();
}
public void print(){
System.out.println("main in static inner class");
}
}
public class TestMain {
public static void main(String[] args) {
// TODO Auto-generated method stub
// new MainInStaticClass().print();
MainInStaticClass.Main.main();
new MainInStaticClass.Main();
}
}
二、靜態(tài)內部類的使用限制。
將某個內部類定義為靜態(tài)類,跟將其他類定義為靜態(tài)類的方法基本相同,引用規(guī)則也基本一致。不過其細節(jié)方面仍然有很大的不同。具體來說,主要有如下幾個地方要引起各位程序開發(fā)人員的注意。
一是靜態(tài)成員(包括靜態(tài)變量與靜態(tài)成員)的定義。一般情況下,如果一個內部類不是被定義成靜態(tài)內部類,那么在定義成員變量或者成員方法的時候,是不能夠被定義成靜態(tài)成員變量與靜態(tài)成員方法的。也就是說,在非靜態(tài)內部類中不可以聲明靜態(tài)成員。如現(xiàn)在在一個student類中定義了一個內部類age,如果沒有將這個類利用static關鍵字修飾,即沒有定義為靜態(tài)類,那么在這個內部類中如果要利用static關鍵字來修飾某個成員方法或者成員變量是不允許的。在編譯的時候就通不過。故程序開發(fā)人員需要注意,只有將某個內部類修飾為靜態(tài)類,然后才能夠在這個類中定義靜態(tài)的成員變量與成員方法。這是靜態(tài)內部類都有的一個特性。也正是因為這個原因,有時候少了這個靜態(tài)的內部類,很多工作就無法完成。或者說要繞一個大圈才能夠實現(xiàn)某個用戶的需求。這也是靜態(tài)的內部類之所以要存在的一個重要原因。
二是在成員的引用上,有比較大的限制。一般的非靜態(tài)內部類,可以隨意的訪問外部類中的成員變量與成員方法。即使這些成員方法被修飾為private(私有的成員變量或者方法),其非靜態(tài)內部類都可以隨意的訪問。則是非靜態(tài)內部類的特權。因為在其他類中是無法訪問被定義為私有的成員變量或則方法。但是如果一個內部類被定義為靜態(tài)的,那么在銀用外部類的成員方法或則成員變量的時候,就會有諸多的限制。如不能夠從靜態(tài)內部類的對象中訪問外部類的非靜態(tài)成員(包括成員變量與成員方法)。這是什么意思呢?如果在外部類中定義了兩個變量,一個是非靜態(tài)的變量,一個是靜態(tài)的變量。那么在靜態(tài)內部類中,無論在成員方法內部還是在其他地方,都只能夠引用外部類中的靜態(tài)的變量,而不能夠訪問非靜態(tài)的變量。在靜態(tài)內部類中,可以定義靜態(tài)的方法(也只有在靜態(tài)的內部類中可以定義靜態(tài)的方法),在靜態(tài)方法中引用外部類的成員。但是無論在內部類的什么地方引用,有一個共同點,即都只能夠引用外部類中的靜態(tài)成員方法或者成員變量。對于那些非靜態(tài)的成員變量與成員方法,在靜態(tài)內部類中是無法訪問的。這就是靜態(tài)內部類的最大使用限制。在普通的非靜態(tài)內部類中是沒有這個限制的。也正是這個原因,決定了靜態(tài)內部類只應用在一些特定的場合。其應用范圍遠遠沒有像非靜態(tài)的內部類那樣廣泛。
三是在創(chuàng)建靜態(tài)內部類時不需要將靜態(tài)內部類的實例綁定在外部類的實例上。
通常情況下,在一個類中創(chuàng)建成員內部類的時候,有一個強制性的規(guī)定,即內部類的實例一定要綁定在外部類的實例中。也就是說,在創(chuàng)建內部類之前要先在外部類中要利用new關鍵字來創(chuàng)建這個內部類的對象。如此的話如果從外部類中初始化一個內部類對象,那么內部類對象就會綁定在外部類對象上。也就是說,普通非靜態(tài)內部類的對象是依附在外部類對象之中的。但是,如果成員開發(fā)人員創(chuàng)建的時靜態(tài)內部類,那么這就又另當別論了。通常情況下,程序員在定義靜態(tài)內部類的時候,是不需要定義綁定在外部類的實例上的。也就是說,要在一個外部類中定義一個靜態(tài)的內部類,不需要利用關鍵字new來創(chuàng)建內部類的實例。即在創(chuàng)建靜態(tài)類內部對象時,不需要其外部類的對象。
newMainInStaticClass.Main();
具體為什么會這樣,一般程序開發(fā)人員不需要了解這么深入,只需要記住有這個規(guī)則即可。在定義靜態(tài)內部類的時候,千萬不要犯畫蛇添足的錯誤。
從以上的分析中可以看出,靜態(tài)內部類與非靜態(tài)的內部類還是有很大的不同的。一般程序開發(fā)人員可以這么理解,非靜態(tài)的內部類對象隱式地在外部類中保存了一個引用,指向創(chuàng)建它的外部類對象。不管這么理解,程序開發(fā)人員都需要牢記靜態(tài)內部類與非靜態(tài)內部類的差異。如是否可以創(chuàng)建靜態(tài)的成員方法與成員變量(靜態(tài)內部類可以創(chuàng)建靜態(tài)的成員而非靜態(tài)的內部類不可以)、對于訪問外部類的成員的限制(靜態(tài)內部類只可以訪問外部類中的靜態(tài)成員變量與成員方法而非靜態(tài)的內部類即可以訪問靜態(tài)的也可以訪問非靜態(tài)的外部類成員方法與成員變量)。這兩個差異是靜態(tài)內部類與非靜態(tài)外部類最大的差異,也是靜態(tài)內部類之所以存在的原因。了解了這個差異之后,程序開發(fā)人員還需要知道,在什么情況下該使用靜態(tài)內部類。如在程序測試的時候,為了避免在各個Java源文件中書寫主方法的代碼,可以將主方法寫入到靜態(tài)內部類中,以減少代碼的書寫量,讓代碼更加的簡潔。
總之,靜態(tài)內部類在Java語言中是一個很特殊的類,跟普通的靜態(tài)類以及非靜態(tài)的內部類都有很大的差異。作為程序開發(fā)人員,必須要知道他們之間的差異,并在實際工作中在合適的地方采用合適的類。不過總的來說,靜態(tài)內部類的使用頻率并不是很高。但是在有一些場合,如果沒有這個內部靜態(tài)類的話,可能會起到事倍功半的反面效果
三、實例化
看了以上內容后,下面我整體測試了一下:
首先大家需要明白,靜態(tài)內部類只是不依附與外部類,它里面的變量和方法也沒有說一定得是靜態(tài)的,下面拿代碼說事:
public class Test {
public static void main(String[] args){
MyInnerStaticClass inner=new MyInnerStaticClass();
inner.a=10;
inner.b="abc";
System.out.println(inner.a+" "+inner.b);
}
static class MyInnerStaticClass{
int a;
String b;
}
}
public class Test {
public static void main(String[] args){
MyInnerStaticClass inner=new MyInnerStaticClass();
inner.a=10;
inner.b="abc";
System.out.println(inner.a+" "+inner.b);
}
static class MyInnerStaticClass{
int a;
String b;
}
}
上述代碼將靜態(tài)匿名類用new實例化了,運行后輸入10 abc,正確!
總結
以上就是本文關于java中staticclass靜態(tài)類詳解的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關文章
在已經使用mybatis的項目里引入mybatis-plus,結果不能共存的解決
這篇文章主要介紹了在已經使用mybatis的項目里引入mybatis-plus,結果不能共存的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
Jmeter 中 CSV 如何參數化測試數據并實現(xiàn)自動斷言示例詳解
這篇文章主要介紹了Jmeter 中 CSV 如何參數化測試數據并實現(xiàn)自動斷言,本文通過示例給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07
SpringBoot如何處理@KafkaListener消息
Spring通過KafkaMessageListenerContainer、ConcurrentMessageListenerContainer等組件實現(xiàn)Kafka消息的監(jiān)聽和處理,并通過@KafkaListener注解將業(yè)務邏輯與Kafka消費者連接起來,Spring?Boot自動配置Kafka相關組件,簡化了Kafka的使用2024-12-12

