[.NET] 建构子中传递子对象的对象
在設(shè)計(jì)對(duì)象繼承的時(shí)候,父對(duì)象建構(gòu)子會(huì)需要一些參數(shù),這些參數(shù)可以由子對(duì)象建構(gòu)子透過base關(guān)鍵詞來提供。
?
namespace Test001 {public class ParentClass{// Constructorspublic ParentClass(IEnumerable<string> dataCollection){this.DataCollection = dataCollection;}// Propertiespublic IEnumerable<string> DataCollection { get; private set; }}public class ChildClass : ParentClass{// Constructorspublic ChildClass() : base(new List<string>()) { }} }但是如果子對(duì)象,要使用這個(gè)傳遞給父對(duì)象的參數(shù),就需要一點(diǎn)小技巧才能取得了。先來看一開始解決的想法是,先建立子對(duì)象的屬性對(duì)象,然后再傳遞給父對(duì)象。這個(gè)方法很快就失敗,光是編譯就不過了….。對(duì)象的建立是先跑建構(gòu)子、然后生出對(duì)象。在建構(gòu)子的階段,就要使用對(duì)象的屬性,一定是失敗的。
?
namespace Test002 {public class ParentClass{// Constructorspublic ParentClass(IEnumerable<string> dataCollection){this.DataCollection = dataCollection;}// Propertiespublic IEnumerable<string> DataCollection { get; private set; }}public class ChildClass : ParentClass{// Fieldsprivate readonly List<string> _dataCollection = new List<string>();// Constructorsprivate ChildClass() : base(_dataCollection) { }} }?
想了一下,換個(gè)角度去解決這個(gè)問題。干脆另外再開一個(gè)子對(duì)象的建構(gòu)子,先建立要傳給父對(duì)象的對(duì)象,然后不直接傳給父對(duì)象的建構(gòu)子,而是傳給子對(duì)象自己的建構(gòu)子,然后這個(gè)建構(gòu)子在傳遞給父對(duì)象。寫到我眼睛都花了,好像繞口令….。直接看程序代碼吧,其實(shí)還蠻簡(jiǎn)單就可以完成這個(gè)小小的設(shè)計(jì):
?
namespace Test003 {public class ParentClass{// Constructorspublic ParentClass(IEnumerable<string> dataCollection){this.DataCollection = dataCollection;}// Propertiespublic IEnumerable<string> DataCollection { get; private set; }}public class ChildClass : ParentClass{// Fieldsprivate readonly List<string> _dataCollection = null;// Constructorspublic ChildClass() : this(new List<string>()) { }private ChildClass(List<string> dataCollection): base(dataCollection){_dataCollection = dataCollection;}} }轉(zhuǎn)載于:https://www.cnblogs.com/clark159/archive/2012/09/15/2686035.html
總結(jié)
以上是生活随笔為你收集整理的[.NET] 建构子中传递子对象的对象的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Linux常用文件和目录操作
- 下一篇: ASP.NET跨页面传值技巧总结