假設域被定義為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());
版權聲明:本文博客原創文章,博客,未經同意,不得轉載。