不能不說的C#特性-對象集合初始化器
[2] 不能不說的C#特性-對象集合初始化器
系列文章導航:
不能不說的C#特性-迭代器(下),yield以及流的延遲計算
走進Linq-Linq to SQL How do I(1)
走進Linq-Linq to SQL How do I(2)
走進Linq-Linq to SQL How do I(3)
走進Linq-Linq to SQL源代碼賞析 Table的獲取過程
走進Linq-Linq to SQL源代碼賞析之Provider的初始化
走進Linq-Linq to SQL源代碼賞析,通過Linq to SQL看Linq
在寫一些實體類的時候,我們往往在寫構造方法的時候思考很長時間,除了一個無參構造器外還在想需要寫幾個構造器呢?哪些參數是需要初始化的。現在你再也不需要為這事煩惱了。C# 3.0為你提供了對象集合初始化器:
/// 圖書類
///
public class Book
{
///
/// 圖書名稱
///
public string Title { get; set; }
///
/// 單價
///
public float Price { get; set; }
///
/// 作者
///
public string Author { get; set; }
///
/// ISBN號
///
public string ISBN { get; set; }
}
//對象初始化器
Book book = new Book { Title="Inside COM",ISBN="123-456-789"};
現在你想初始化幾個就初始化幾個,不需要出現這種情況:















這一串的構造方法都是為了應付不同的初始化情況。好了,來看看對象初始化器編譯器在后面為我們做了些什么呢? 使用Reflector反編譯程序集:
<>g__initLocal0.Title = "Inside COM";
<>g__initLocal0.ISBN = "123-456-789";
Book book = <>g__initLocal0;
C#編譯器生成了一個新的局部變量<>g__initLocal0,調用Book的默認無參構造方法初始化它,然后對它的屬性進行賦值,最后將這個局部變量賦值給book。看到這里,我們應該想到,要使用對象初始化器,那么這個對象必須有一個無參構造方法,如果你給這個方法寫了一個有參構造方法而將它的默認無參構造方法覆蓋了并且沒有提供一個新的無參構造方法,那么使用對象初始化器編譯的時候是不會通過的(不過想不通,為啥C#編譯器生成這么一個奇怪的局部變量名字,還有為啥不直接使用book呢)。像下面的代碼不更好:
book.Title = "Inside COM";
book.ISBN = "123-456-789";
后來我發現我是在debug模式下編譯的,換到release模式下變成了這樣:
<>g__initLocal0.Title = "Inside COM";
<>g__initLocal0.ISBN = "123-456-789";