在設(shè)計對象繼承的時候,父對象建構(gòu)子會需要一些參數(shù),這些參數(shù)可以由子對象建構(gòu)子透過base關(guān)鍵詞來提供。
復制代碼 代碼如下:
namespace Test001
{
public class ParentClass
{
// Constructors
public ParentClass(IEnumerablestring> dataCollection)
{
this.DataCollection = dataCollection;
}
// Properties
public IEnumerablestring> DataCollection { get; private set; }
}
public class ChildClass : ParentClass
{
// Constructors
public ChildClass() : base(new Liststring>()) { }
}
}
但是如果子對象,要使用這個傳遞給父對象的參數(shù),就需要一點小技巧才能取得了。先來看一開始解決的想法是,先建立子對象的屬性對象,然后再傳遞給父對象。這個方法很快就失敗,光是編譯就不過了….。對象的建立是先跑建構(gòu)子、然后生出對象。在建構(gòu)子的階段,就要使用對象的屬性,一定是失敗的。
復制代碼 代碼如下:
namespace Test002
{
public class ParentClass
{
// Constructors
public ParentClass(IEnumerablestring> dataCollection)
{
this.DataCollection = dataCollection;
}
// Properties
public IEnumerablestring> DataCollection { get; private set; }
}
public class ChildClass : ParentClass
{
// Fields
private readonly Liststring> _dataCollection = new Liststring>();
// Constructors
private ChildClass() : base(_dataCollection) { }
}
}
想了一下,換個角度去解決這個問題。干脆另外再開一個子對象的建構(gòu)子,先建立要傳給父對象的對象,然后不直接傳給父對象的建構(gòu)子,而是傳給子對象自己的建構(gòu)子,然后這個建構(gòu)子在傳遞給父對象。寫到我眼睛都花了,好像繞口令….。直接看程序代碼吧,其實還蠻簡單就可以完成這個小小的設(shè)計:
復制代碼 代碼如下:
namespace Test003
{
public class ParentClass
{
// Constructors
public ParentClass(IEnumerablestring> dataCollection)
{
this.DataCollection = dataCollection;
}
// Properties
public IEnumerablestring> DataCollection { get; private set; }
}
public class ChildClass : ParentClass
{
// Fields
private readonly Liststring> _dataCollection = null;
// Constructors
public ChildClass() : this(new Liststring>()) { }
private ChildClass(Liststring> dataCollection)
: base(dataCollection)
{
_dataCollection = dataCollection;
}
}
}