java靜態方法和實例方法的區別

轉自:http://www.cdtarena.com/javapx/201306/8776.html

  靜態方法和實例方法的區別主要體現在兩個方面:
  在外部調用靜態方法時,可以使用"類名.方法名"的方式,也可以使用"對象名.方法名"的方式。而實例方法只有後面這種方式。也就是說,調用靜態方法可以無需創建對象。
  靜態方法在訪問本類的成員時,只允許訪問靜態成員(即靜態成員變量和靜態方法),而不允許訪問實例成員變量和實例方法;實例方法則無此限制。
  下面幾個例子展示了這一區別。
  1、調用靜態方法示例。
  <SPAN style="FONT-SIZE: 18px"><STRONG>//-----------hasStaticMethod.java-----------------
  public class hasStaticMethod{
  //定義一個靜態方法
  public static void callMe(){
  System.out.println("This is a static method.");
  }
  }
  下面這個程序使用兩種形式來調用靜態方法。http://www.cdtarena.com/class.html
  //-----------invokeStaticMethod.java-----------------
  public class invokeStaticMethod{
  public static void main(String args[]){
  hasStaticMethod.callMe();  //不創建對象,直接調用靜態方法
  hasStaticMethod oa = new hasStaticMethod();   //創建一個對象
  oa.callMe();      //利用對象來調用靜態方法
  }
  } </STRONG></SPAN>
  程序兩次調用靜態方法,都是允許的,程序的輸出如下:
  This is a static method.This is a static method.
  允許不創建對象而調用靜態方法,是Java爲了減少程序員調用某些常用方法時的麻煩,而允許程序員按照傳統的C語言中使用函數的方式來使用方法。典型的例子是前面某些程序中使用"Math.ramdon()"來獲取隨機數。
  還有一個很典型的代表就是數組的處理工具Arrays
  2、靜態方法訪問成員變量示例。
  <SPAN style="FONT-SIZE: 18px"><STRONG>//-----------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();   //正確,可以調用靜態方法
  }
  } </STRONG></SPAN>
  本例其實可以概括成一句話:靜態方法只能訪問靜態成員,實例方法可以訪問靜態和實例成員。之所以不允許靜態方法訪問實例成員變量,是因爲實例成員變量是屬於某個對象的,而靜態方法在執行時,並不一定存在對象。同樣,因爲實例方法可以訪問實例成員變量,如果允許靜態方法調用實例方法,將間接地允許它使用實例成員變量,所以它也不能調用實例方法。基於同樣的道理,靜態方法中也不能使用關鍵字this。 main()方法是一個典型的靜態方法,它同樣遵循一般靜態方法的規則,所以它可以由系統在創建對象之前就調用。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章