在C#中,是否需要调用基本构造函数?
-
09-06-2019 - |
题
在 C# 中,如果我有一个带有默认构造函数的继承类,我是否必须显式调用基类的构造函数还是会隐式调用它?
class BaseClass
{
public BaseClass()
{
// ... some code
}
}
class MyClass : BaseClass
{
public MyClass() // Do I need to put ": base()" here or is it implied?
{
// ... some code
}
}
解决方案
您不需要显式调用基本构造函数,它将被隐式调用。
稍微扩展您的示例并创建一个控制台应用程序,您可以自己验证此行为:
using System;
namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
MyClass foo = new MyClass();
Console.ReadLine();
}
}
class BaseClass
{
public BaseClass()
{
Console.WriteLine("BaseClass constructor called.");
}
}
class MyClass : BaseClass
{
public MyClass()
{
Console.WriteLine("MyClass constructor called.");
}
}
}
其他提示
它是隐含的,只要它是无参数的。这是因为你 需要实现接受值的构造函数, ,请参阅下面的代码示例:
public class SuperClassEmptyCtor
{
public SuperClassEmptyCtor()
{
// Default Ctor
}
}
public class SubClassA : SuperClassEmptyCtor
{
// No Ctor's this is fine since we have
// a default (empty ctor in the base)
}
public class SuperClassCtor
{
public SuperClassCtor(string value)
{
// Default Ctor
}
}
public class SubClassB : SuperClassCtor
{
// This fails because we need to satisfy
// the ctor for the base class.
}
public class SubClassC : SuperClassCtor
{
public SubClassC(string value) : base(value)
{
// make it easy and pipe the params
// straight to the base!
}
}
它隐含于基本无参数构造函数,但当前类中的默认值需要它:
public class BaseClass {
protected string X;
public BaseClass() {
this.X = "Foo";
}
}
public class MyClass : BaseClass
{
public MyClass()
// no ref to base needed
{
// initialise stuff
this.X = "bar";
}
public MyClass(int param1, string param2)
:this() // This is needed to hit the parameterless ..ctor
{
// this.X will be "bar"
}
public MyClass(string param1, int param2)
// :base() // can be implied
{
// this.X will be "foo"
}
}
这是暗示的。
派生类是建立在基类之上的。如果您考虑一下,必须先在内存中实例化基对象,然后才能将派生类附加到基对象。因此,基础对象将在创建派生对象的过程中创建。所以不,你不会调用构造函数。
AFAIK,如果您需要向其传递任何值,则只需调用基本构造函数。
您不需要显式调用基本构造函数,它会隐式调用,但有时您需要将参数传递给构造函数,在这种情况下,您可以执行以下操作:
using System;
namespace StackOverflow.Examples
{
class Program
{
static void Main(string[] args)
{
NewClass foo = new NewClass("parameter1","parameter2");
Console.WriteLine(foo.GetUpperParameter());
Console.ReadKey();
}
}
interface IClass
{
string GetUpperParameter();
}
class BaseClass : IClass
{
private string parameter;
public BaseClass (string someParameter)
{
this.parameter = someParameter;
}
public string GetUpperParameter()
{
return this.parameter.ToUpper();
}
}
class NewClass : IClass
{
private BaseClass internalClass;
private string newParameter;
public NewClass (string someParameter, string newParameter)
{
this.internalClass = new BaseClass(someParameter);
this.newParameter = newParameter;
}
public string GetUpperParameter()
{
return this.internalClass.GetUpperParameter() + this.newParameter.ToUpper();
}
}
}
笔记:如果有人知道更好的解决方案请告诉我。
不隶属于 StackOverflow