Java靜態字段(屬性、方法、類別)


假設域被定義為static,那么每個中僅僅有一個這種域。作為對照,每個對象對於全部的實例域卻都有自己的一份拷貝。

比如,假定須要給每個雇員賦予唯一的標識碼。

這里給Employee類加入一個實例域id和一個靜態域nextId:

class Employee{
    ......
    private int id;
    private static int nextId = 1;
}

如今,每個雇員對象都有一個自己的id域,但這個類的全部實例將共享一個nextId域。

換句話說,假設有1000個Employee類的對象。

則有1000個實例域id,當中任一實例使用了setId()方法后。Employee類的靜態域都會變成設置后的值。可是,僅僅有一個靜態域nextId。

即使沒有一個雇員對象。靜態域nextId也存在它屬於類,而不屬於不論什么獨立的對象。從靜態域通過類名直接調用,實例域通過(類的)實例調用,也可佐證。

項目中遇到的一個樣例:假設寫一個類XDialog繼承Dialog,XDialog里面有個域變量private List<String> items;我每次要顯示一個對話框時都new XDialog();這時這個對話框就有了一個items拷貝。new N個XDialog就有N個相應的items拷貝。但若items是指當前用戶的好友數目,那么XDialog對話框中就應該時時顯示正確的上/下線好友。若是N個items拷貝,就每次都初始化了items。不能達到同步的目的,且效率低。這時用statickeyword就攻克了全部問題,僅僅需聲明privatestatic List<String> items;這時items為XDialog這個類全部,而非某個實現。Perfect!

再來看下靜態方法

靜態方法是不能向對象實施操作的方法。

比如,Math.pow(x, a),它在運算的時候,不使用不論什么Math對象。換句話說,沒有隱式的參數(this)。

能夠覺得靜態方法是沒有this參數的方法。(在一個非靜態的方法中。this參數表示該方法的隱式參數。)作為對照:非靜態方法的調用(this.)pow();

由於靜態方法不能操作對象,所以不能在靜態方法中訪問實例域。可是。靜態方法能夠訪問自身類中的靜態域

public static int getNextId(){
    return nextId;//return static field
}
通過類名調用這種方法:int n = Employee.getNextId();

注:靜態域不能直接訪問實例域(由於它是與類相關的而不是某個對象),但實例域可直接訪問靜態域(由於實例域是派生於類的)。

假設harry是一個Employee對象。可用harry.getNextId()來替代Employee.getNextId()。只是,這樣的方式非常easy讓人迷惑。由於getNextId方法計算的結果與harry毫無關系。故建議使用類名。而不是對象來調用靜態方法。

在以下兩種情況下使用靜態方法:

1.當一個方法不須要訪問對象狀態。其所需參數都是通過顯式提供的(比如Math.pow)。

2.當一個方法僅僅須要訪問類的靜態域(比如Employee.getNextId)。

接下來看下靜態內部類

有時候,使用內部類僅僅是為了把一個類隱藏在另外一個類的內部。並不須要內部類引用外圍類對象。為此,能夠將內部類聲明為static。以便取消產生的引用。

靜態內部類的對象除了沒有對生成它的外圍類對象的引用特權外,與其它全部內部類全然一樣。

比如。定義靜態內部類Pair:

class ArrayAlg{
    public static class Pair{//不須要內部類引用外圍對象。用static斷絕這樣的引用。
      private double first;
      private double second;
      public Pair(double f, double s){
          first = f;
          second = s;
      }
      public double getFirst(){
          return first;
      }
      public double getSecond(){
          return second;
      }
      public static Pair minmax(double[] values){
          double min = Double.MAX_VALUE;
          double max = Double.MIN_VALUE;
          for(double v:values){
              if(min>v) min = v;
              if(max<v) max = v;
          }
          return new Pair(min,max);
      }
    }//end Pair
}

當中,ArrayAlg是內部類。Pair是靜態內部類。
在主main中:

ArrayAlg.Pair p = ArrayAlg.Pair.minmax(d);//d:double數組
System.out.println("min="+p.getFirst()+",max="+p.getSecond());

版權聲明:本文博客原創文章,博客,未經同意,不得轉載。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM