構造器名與類名一致。
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。
任何基於棧的值類型字段都必須先寫入再讀取,否則會造成安全漏洞。
在訪問值類型的任何一個字段之前都要對全部字段進行賦值,所以值類型的任何構造器都必須初始化值類型的全部字段。