構造器名與類名一致。 1。實例構造器與類(引用類型) 構造器是允許將類型的實力初始化為良好狀態的一種特殊方法。 創建一個引用類型的實例時(類),首先為實例的數據欄位分配記憶體,然後初始化對象的附加欄位(類型對象指針和同步索引快),最後調用類型的實例構造器來設置對象的初始狀態。 new一個類所發生的事: ...
構造器名與類名一致。
1。實例構造器與類(引用類型)
構造器是允許將類型的實力初始化為良好狀態的一種特殊方法。
創建一個引用類型的實例時(類),首先為實例的數據欄位分配記憶體,然後初始化對象的附加欄位(類型對象指針和同步索引快),最後調用類型的實例構造器來設置對象的初始狀態。
new一個類所發生的事:分配記憶體(托管堆上)——》初始化額外開銷(類型對象指針和同步索引快)——》調用類型的實力構造器(設置對象的出事狀態)
構造引用類型的對象時,在調用類型的實例構造器之前,為對象分配的記憶體總是先輩歸為零。構造器沒有顯示重寫的所有欄位保證都有一個0或null值。
實例構造器永遠不能被繼承,也就是類只有類自己定義的實例構造器。
因為不能繼承實例構造器,virtual,new,override,sealed和abstract不能用於實例構造器。
如果定義的類沒有顯示定義任何構造器,c#編譯器會預設定義一個調用了基類的(無參)構造器。
一個類型可以定義多個實例構造器。每個構造器都必須有不同的簽名(參數),每個構造器夠可以有不同的可訪問性。
類的實例構造器在訪問從基類繼承的任何欄位之前,必須先調用基類的構造器。
internal sealed class SomeType { private int a = 5; private string b = "helllo"; private double c = 3.14; private Boolean d =false ; //下麵為一些構造器 //public SomeType(){} // private SomeType(int aa) { a = 10; } // protected SomeType(string bb){} // internal SomeType(double cc) { c = 1.41; } // public SomeType(Boolean dd) { a = 1;b = "HI"; c = 1.73;d = true; } //該構造器將所有欄位都設為預設值,然後後邊構造器實時調用該構造器 public SomeType() { a = 10; b = "HI"; c = 1.41; d = false; } //所有欄位設為預設,修改a private SomeType(int x) : this(){ a = 5; }
//所有欄位設為預設,修改a,d
public SomeType(int x, Boolean y) : this() { a = 5;d = true; } }
2.實例構造器與值類型
CLR總是允許創建值類型的實例,並沒有辦法阻止值類型的實例化。所以值類型並不需要定義構造器。
c#編譯器不會為值類型生成預設的無參構造器。
值類型的構造器只有在顯示調用的時候才會執行。
值類型定義的無參構造器不會被c#編譯。沒有無參構造器,值類型的欄位總是初始化為0或null。
任何基於棧的值類型欄位都必須先寫入再讀取,否則會造成安全漏洞。
在訪問值類型的任何一個欄位之前都要對全部欄位進行賦值,所以值類型的任何構造器都必須初始化值類型的全部欄位。