1

如果我运行以下 C# 代码,它只会输出BaseClass() called,这是可以理解的。但是,如果我想BaseClass.CreateInstance()始终返回被调用的类的实例,即使它实际上是继承该方法的不同类,该怎么办?

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace Example
{
    class BaseClass
    {
        public BaseClass()
        {
            Console.WriteLine("BaseClass() called");
        }

        public static BaseClass CreateInstance()
        {
            return new BaseClass();
        }
    }

    class DerivedClass : BaseClass
    {
        public DerivedClass()
            : base()
        {
            Console.WriteLine("DerivedClass() called");
        }
    }

    class Program
    {
        static void Main(string[] args)
        {
            DerivedClass.CreateInstance();
            Console.ReadLine(); //pause so output is readable
        }
    }
}
4

2 回答 2

3

你实际上并没有调用它DerivedClass。编译器看到BaseClass(而不是DerivedClass)上有一个静态方法,并自动将其转换为对BaseClass.CreateInstance.

一种选择是使用泛型来处理这个问题:

public static T CreateInstance<T>() where T : BaseClass, new()
{
    return new T();
}

这将允许您编写:

DerivedClass dc = BaseClass.CreateInstance<DerivedClass>();
于 2013-09-25T20:44:39.957 回答
0

你没有DerivedClass在你的CreateInstance方法中创建一个实例,所以你没有得到一个实例,因此它的构造函数没有被调用。

如果你这样做var bla = new DerivedClass(),它会调用它的构造函数。

于 2013-09-25T20:43:14.990 回答