所以我有一个Student类,我想重载构造函数所以如果我回链接就像这样.
public class Student{ string name; int ID; public Student() { } public Student(string name) { this.name = name; } public Student(string name,int ID) :this(name) { this.ID = ID;
但这显然是不好的,因为我们想要一个构造函数中的所有代码是出于什么原因?易于阅读?
public Student() : this(null,0) { } public Student(string name) : this(name,0) { } public Student(string name,int ID) { this.name = name; this.ID = ID; }
如果我这样做,那么如果我们添加一个像字符串major这样的新字段会发生什么呢?如果我转发链接,那么我使用添加的字段创建一个新的重载构造函数.但现在我必须更改所有其他构造函数以调用新构造函数.如果我进行向后链接,我只需创建一个新的构造函数并调用前一个重载的构造函数.
public Student(string name,int ID,string major):this(name,ID) { this.major=major; }
这似乎比OOP更好,但我的教科书中的所有示例都显示了前向链接,并且没有说明为什么我不应该使用反向链接.
如果我使用命名/可选参数,那就更容易了.
public Student(string name = null,int ID = 0,string major = null) { this.name = name; this.ID = ID; this.major = major; }
如果我需要另一个字段,我只需要编辑唯一的构造函数.这似乎遵循OOP原则最好还是我错了?它至少消除了代码重复.我的任务是“按照OOP的原则实施学生课程”.我知道所有这些都是有效的,但是编码构造函数的最佳/可接受的方式之一是什么?我缺少命名/可选参数的缺点吗?作为一个初学者,有很多方法来编写这个,这是非常令人困惑的.
解决方法 没有最好的方法,因为它们不同,每种方法都有优点和缺点.从C#1.0开始,独立构造函数和链式构造函数可用,在大多数情况下我们使用链式构造函数,但有时我们必须使用前者,如果两个构造函数有完全不同的东西要处理.
class Student{ public Student() { DoSomething(); } public Student(string name) { this.name = name; DoAnotherThing(); }}
与可选参数构造函数相比,上面两个更长,但说实话,它们更安全.考虑以下情况:
public class Student{ public Student(string firstname = null,string lastname = null) { this.Firstname = firstname; this.Lastname = lastname; } public string Firstname { get; set; } public string Lastname { get; set; }}//it's working fine//var danny = new Student("danny","chen");//as the business grows a lot of students need a mIDdle namepublic Student(string firstname = null,string mIDdlename = null,string lastname = null){ this.Firstname = firstname; this.MIDdlename = mIDdlename; this.Lastname = lastname;}//for a better sequence the programmer adds mIDdlename between the existing two,bang!
他们之间的另一个区别是使用反射.可选参数不会为您生成更多构造函数,如果使用反射调用构造函数,则不会应用默认值.
总结以上是内存溢出为你收集整理的c# – 构造函数链接或使用命名/可选参数全部内容,希望文章能够帮你解决c# – 构造函数链接或使用命名/可选参数所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)