靜態方法和實例方法的區別主要體如今兩個方面:
在外部調用靜態方法時,可使用"類名.方法名"的方式,也可使用"對象名.方法名"的方式。而實例方法只有後面這種方式。也就是說,調用靜態方法能夠無需建立對象。
靜態方法在訪問本類的成員時,只容許訪問靜態成員(即靜態成員變量和靜態方法),而不容許訪問實例成員變量和實例方法;實例方法則無此限制。
下面幾個例子展現了這一區別。
一、調用靜態方法示例。
//-----------文件名hasStaticMethod.java,程序編號1-----------------public class hasStaticMethod{//定義一個靜態方法public static void callMe(){System.out.println("This is a static method.");}}
下面這個程序使用兩種形式來調用靜態方法。
//-----------文件名invokeStaticMethod.java,2-----------------public class invokeStaticMethod{public static void main(String args[]){hasStaticMethod.callMe(); //不建立對象,直接調用靜態方法 hasStaticMethod oa = new hasStaticMethod(); //建立一個對象oa.callMe(); //利用對象來調用靜態方法}}
程序3.36兩次調用靜態方法,都是容許的,程序的輸出以下:
This is a static method.This is a static method.
容許不建立對象而調用靜態方法,是Java爲了減小程序員調用某些經常使用方法時的麻煩,而容許程序員按照傳統的C語言中使用函數的方式來使用方法。典型的例子是前面某些程序中使用"Math.ramdon()"來獲取隨機數。
二、靜態方法訪問成員變量示例。
//-----------文件名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(); //正確,能夠調用靜態方法}}
本例其實能夠歸納成一句話:靜態方法只能訪問靜態成員,實例方法能夠訪問靜態和實例成員。之因此不容許靜態方法訪問實例成員變量,是由於實例成員變量是屬於某個對象的,而靜態方法在執行時,並不必定存在對象。一樣,由於實例方法能夠訪問實例成員變量,若是容許靜態方法調用實例方法,將間接地容許它使用實例成員變量,因此它也不能調用實例方法。基於一樣的道理,靜態方法中也不能使用關鍵字this。
main()方法是一個典型的靜態方法,它一樣遵循通常靜態方法的規則,因此它能夠由系統在建立對象以前就調用。java