本文目錄一覽:
- 1、java中的靜態方法有什麼作用?
- 2、Java中靜態方法與非靜態方法的區別?
- 3、北大青鳥設計培訓:JAVA構造方法靜態方法?
- 4、java中什麼是靜態方法
- 5、Java中的靜態方法有修飾符嗎,靜態方法屬於成員方法嗎?
- 6、java怎麼在靜態方法中使用動態方法?
java中的靜態方法有什麼作用?
靜態方法是屬於類的,內存必須為它分配內存空間,這個空間一直由靜態方法佔用,內存管理器不會由於靜態方法沒有被調用而將靜態方法的存儲空間收回,這樣如果將所有的方法都聲明為靜態方法,就會佔用大量的內存空間,最後是系統變慢。而普通的成員方法是由對象調用的,內存並不會一直為起分配內存,只有調用的時候才為其分配存儲空間,而當其沒有被調用時,存儲空間就會被內存管理其收回,釋放沒有用的空間,提高的系統的運行速率!希望對樓主有幫助!
Java中靜態方法與非靜態方法的區別?
靜態方法和實例方法的區別主要體現在兩個方面:\x0d\x0a\x0d\x0a在外部調用靜態方法時,可以使用”類名.方法名”的方式,也可以使用”對象名.方法名”的方式。而實例方法只有後面這種方式。也就是說,調用靜態方法可以無需創建對象。\x0d\x0a\x0d\x0a靜態方法在訪問本類的成員時,只允許訪問靜態成員(即靜態成員變數和靜態方法),而不允許訪問實例成員變數和實例方法;實例方法則無此限制。\x0d\x0a\x0d\x0a下面幾個例子展示了這一區別。\x0d\x0a\x0d\x0a1、調用靜態方法示例。\x0d\x0a\x0d\x0a//———–文件名hasStaticMethod.java,程序編號1—————–public class hasStaticMethod{//定義一個靜態方法public static void callMe(){System.out.println(“This is a static method.”);}}\x0d\x0a \x0d\x0a下面這個程序使用兩種形式來調用靜態方法。\x0d\x0a//———–文件名invokeStaticMethod.java,2—————–public class invokeStaticMethod{public static void main(String args[]){hasStaticMethod.callMe(); //不創建對象,直接調用靜態方法 hasStaticMethod oa = new hasStaticMethod(); //創建一個對象oa.callMe(); //利用對象來調用靜態方法}} \x0d\x0a程序3.36兩次調用靜態方法,都是允許的,程序的輸出如下:\x0d\x0aThis is a static method.This is a static method. \x0d\x0a\x0d\x0a允許不創建對象而調用靜態方法,是Java為了減少程序員調用某些常用方法時的麻煩,而允許程序員按照傳統的C語言中使用函數的方式來使用方法。典型的例子是前面某些程序中使用”Math.ramdon()”來獲取隨機數。\x0d\x0a\x0d\x0a2、靜態方法訪問成員變數示例。\x0d\x0a\x0d\x0a//———–文件名accessMember.java,程序編號3.37—————–class accessMember{private static int sa; //定義一個靜態成員變數private int ia; //定義一個實例成員變數//下面定義一個靜態方法static void statMethod(){int i = 0; //正確,可以有自己的局部變數sa = 10; //正確,靜態方法可以使用靜態變數otherStat(); //正確,可以調用靜態方法ia = 20; //錯誤,不能使用實例變數insMethod(); //錯誤,不能調用實例方法}static void otherStat(){} //下面定義一個實例方法 void insMethod(){int i = 0; //正確,可以有自己的局部變數sa = 15; //正確,可以使用靜態變數ia = 30; //正確,可以使用實例變數statMethod(); //正確,可以調用靜態方法}} \x0d\x0a\x0d\x0a本例其實可以概括成一句話:靜態方法只能訪問靜態成員,實例方法可以訪問靜態和實例成員。之所以不允許靜態方法訪問實例成員變數,是因為實例成員變數是屬於某個對象的,而靜態方法在執行時,並不一定存在對象。同樣,因為實例方法可以訪問實例成員變數,如果允許靜態方法調用實例方法,將間接地允許它使用實例成員變數,所以它也不能調用實例方法。基於同樣的道理,靜態方法中也不能使用關鍵字this。\x0d\x0a\x0d\x0amain()方法是一個典型的靜態方法,它同樣遵循一般靜態方法的規則,所以它可以由系統在創建對象之前就調用。
北大青鳥設計培訓:JAVA構造方法靜態方法?
構造方法 作用:對對象的屬性(成員變數)進行初始化 寫法: 1.構造方法的方法名與類名完全相同 2.沒有返回值類型(連void都不寫) 3.沒有返回值注意事項: 1.沒寫構造方法 系統則會提供一個無參的構造方法 2.寫了有參的構造方法 系統不會提供無參的構造方法 所以在寫有參的構造方法時最好把無參的也寫上內存表現步驟 1.類載入到方法區 2.載入到方法區的同時。
IT培訓認為靜態變數被載入到方法區的靜態區 3.main入棧 4.在堆內存中創建對象 5.把地址賦值給main函數的對象保存 6.main函數出棧 7.程序結束靜態變數與成員變數的區別: 1.所屬不同: 成員變數:屬於對象的又叫對象變數(實例變數) 靜態變數:屬於類又叫類變數2.內存中的存儲位置: 成員變數:存儲在堆內存 靜態變數:存處在方法區的靜態區3.載入到內存中的時機(生命周期的不同): 成員變數:隨著對象的創建而創建 靜態變數:隨著類的載入而存在
java中什麼是靜態方法
若類的方法前加了static關鍵字,則該方法稱為靜態方法,反之為實例方法。靜態方法為類所有,可以通過對象來使用,也可以通過類來使用。但一般提倡通過類名來使用,因為靜態方法只要定義了類,不必建立類的實例就可使用。靜態方法只能調用靜態變數。
Java中的靜態方法有修飾符嗎,靜態方法屬於成員方法嗎?
在Java中,靜態方法是用static修飾的,同時可以選擇加上public或protected或private訪問修飾符,如果不加也是默認具有包訪問性。 靜態方法是屬於類的靜態成員方法,通常是通過類來調用,通過類的實例也可以調用。
如:
class A
{
public static void f()
{
System.out.println(“類A的靜態方法f”);
}
}
則以下方法都可以調用靜態方法f:
1、通過類來調用
A.f();
2、通過類A的引用變數來調用
A obj;
obj.f();
java怎麼在靜態方法中使用動態方法?
1.靜態的方法在整個應用程序其間存儲在內存中,速度快,但佔用內存. \x0d\x0a class A\x0d\x0a {\x0d\x0a public static string b()\x0d\x0a {\x0d\x0a return “Hello”;\x0d\x0a }\x0d\x0a\x0d\x0a } \x0d\x0a\x0d\x0a用法: A.b(); //調用方便 \x0d\x0a靜態方法可以通過類名直接調用,\x0d\x0a2.動態的方法在先聲明類實例才能調用類中的方法. \x0d\x0a\x0d\x0a class A\x0d\x0a {\x0d\x0a public string b()\x0d\x0a {\x0d\x0a return “Hello”;\x0d\x0a }\x0d\x0a } \x0d\x0a用法: A a = new a(); a.b(); \x0d\x0a3.一般使用頻繁的方法用靜態方法,用的少的方法用動態的。靜態的速度快,占內存。動態的速度相對慢些,但調用完後,立即釋放類,可以節省內存,可以根據自己的需要選擇是用動態方法還是靜態方法。\x0d\x0a4.靜態方法主要的問題就是數據同步的問題。如果你的靜態方法的類中不保存私有變數那麼什麼問題都不會有的。最好是包要操作的數據全部以參數的方式傳到方法中去\x0d\x0a5. 靜態方法是類方法,調用時不需要創建類實例。\x0d\x0a6. 靜態方法是靜態綁定到子類,不是被繼承。
原創文章,作者:KLTX,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/137515.html