クライアントまで、フルのC#である必要があり、ベースのコンストラクタ?

StackOverflow https://stackoverflow.com/questions/18097

  •  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.");
        }
    }
}

他のヒント

では利用でparameterless.こす を実装する必要があるとコンストラクタと価値, は、以下のコード例:

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!
    }
}

この暗黙のための基盤parameterlessコンストラクタではデフォルトのクラス:

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();
        }
    }
}

注意:場の人を知り尽くし、よりよい解決方法を教えて下さい。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top