靜態方法和執行個體方法的區別主要體現在兩個方面:
在外部調用靜態方法時,可以使用"類名.方法名"的方式,也可以使用"對象名.方法名"的方式。而執行個體方法只有後面這種方式。也就是說,調用靜態方法可以無需建立對象。
靜態方法在訪問本類的成員時,只允許訪問靜態成員(即靜態成員變數和靜態方法),而不允許訪問執行個體成員變數和執行個體方法;執行個體方法則無此限制。
下面幾個例子展示了這一區別。
1、調用靜態方法樣本。
//-----------hasStaticMethod.java-----------------
public class hasStaticMethod{
//定義一個靜態方法
public static void callMe(){
System.out.println("This is a static method.");
}
}
下面這個程式使用兩種形式來調用靜態方法。
//-----------invokeStaticMethod.java-----------------
public class invokeStaticMethod{
public static void main(String args[]){
hasStaticMethod.callMe(); //不建立對象,直接調用靜態方法
hasStaticMethod oa = new hasStaticMethod(); //建立一個對象
oa.callMe(); //利用對象來調用靜態方法
}
}
程式兩次調用靜態方法,都是允許的,程式的輸出如下:
This is a static method.This is a static method.
允許不建立對象而調用靜態方法,是Java為了減少程式員調用某些常用方法時的麻煩,而允許程式員按照傳統的C語言中使用函數的方式來使用方法。典型的例子是前面某些程式中使用"Math.ramdon()"來擷取隨機數。
還有一個很典型的代表就是數組的處理工具Arrays
2、靜態方法訪問成員變數樣本。
//-----------accessMember.java-----------------
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()方法是一個典型的靜態方法,它同樣遵循一般靜態方法的規則,所以它可以由系統在建立對象之前就調用。