[转载] 详解Java中静态方法
參考鏈接: Java中的靜態(tài)類
定義: 在類中使用static修飾的靜態(tài)方法會隨著類的定義而被分配和裝載入內(nèi)存中;而非靜態(tài)方法屬于對象的具體實例,只有在類的對象創(chuàng)建時在對象的內(nèi)存中才有這個方法的代碼段。?
注意: 非靜態(tài)方法既可以訪問靜態(tài)數(shù)據(jù)成員 又可以訪問非靜態(tài)數(shù)據(jù)成員,而靜態(tài)方法只能訪問靜態(tài)數(shù)據(jù)成員; 非靜態(tài)方法既可以訪問靜態(tài)方法又可以訪問非靜態(tài)方法,而靜態(tài)方法只能訪問靜態(tài)數(shù)據(jù)方法。?
原因: 因為靜態(tài)方法和靜態(tài)數(shù)據(jù)成員會隨著類的定義而被分配和裝載入內(nèi)存中,而非靜態(tài)方法和非靜態(tài)數(shù)據(jù)成員只有在類的對象創(chuàng)建時在對象的內(nèi)存中才有這個方法的代碼段。?
引用靜態(tài)方法時,可以用類名.方法名或者對象名.方法名的形式。 對以上描述進行驗證的代碼示例:?
import java.util.*;
?
public class TestStatic {
? ? public static void main(String[]args){
? ? ? ? System.out.println(S.getStatic());//使用類名加前綴訪問靜態(tài)方法
? ? ? ? S s=new S();
? ? ? ? System.out.println(s.getStatic());//使用實例化對象名訪問靜態(tài)方法
? ? ? ? System.out.println(s.get());
? ? }
? ? public static class S
? ? {
? ? ? ? private static int a;
? ? ? ? private int t=0;
?
? ? ? ? //靜態(tài)初始器:由static和{}組成,只在類裝載的時候(第一次使用類的時候)執(zhí)行一次,往往用來初始化靜態(tài)變量。
? ? ? ? static{
? ? ? ? ? ? a=10;
? ? ? ? }
?
? ? ? ? //靜態(tài)方法只能訪問靜態(tài)數(shù)據(jù)成員
? ? ? ? public static int getStatic()
? ? ? ? {
? ? ? ? ? ? return a;
? ? ? ? }
?
? ? ? ? public int getT()
? ? ? ? {
? ? ? ? ? ? return t;
? ? ? ? }
?
? ? ? ? //非靜態(tài)方法可以訪問靜態(tài)方法和非靜態(tài)方法
? ? ? ? public int get()
? ? ? ? {
? ? ? ? ? ? getT();
? ? ? ? ? ? getStatic();
? ? ? ? ? ? t=a;//非靜態(tài)方法可以訪問非靜態(tài)數(shù)據(jù)成員和靜態(tài)數(shù)據(jù)成員
? ? ? ? ? ? return t;
? ? ? ? }
? ? }
}
?
總結(jié): (1)static修飾的靜態(tài)方法會隨著類的定義而被分配和裝載入內(nèi)存中,編譯器只為整個類創(chuàng)建了一個靜態(tài)變量的副本,也就是只分配一個內(nèi)存空間,雖然可能有多個實例,但這些實例共享該內(nèi)存,特別值得注意的是,任何一個對象對靜態(tài)數(shù)據(jù)成員的修改,都會影響其它對象。 (2)靜態(tài)不能引用非靜態(tài)這一特性,是由于靜態(tài)的會隨著類的定義而被分配和裝載入內(nèi)存中這一關(guān)鍵點決定的;如果靜態(tài)引用了非靜態(tài)的,根本無法從內(nèi)存中找到非靜態(tài)的代碼段,勢必會出錯,這種做法是Java虛擬機決不允許的。
總結(jié)
以上是生活随笔為你收集整理的[转载] 详解Java中静态方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [转载] java排序compareTo
- 下一篇: [转载] 必须要会回答的Java面试题(