0

我已经使用委托来表示方法 - 但我现在有许多具有相同方法的类(但这些方法中的代码不同)。

有没有办法委派整个班级?

伪代码:

class myModelA
{
     void update()
     {

     }
}

class myModelB
{
     void update()
     {

     }
}



delegate class myModel;

if (x==1)
     myModel = myModelA;
else
     myModel = myModelB;


myModel.update();

我知道我可以委托“üpdate”方法但在现实世界中我有很多方法,我宁愿只是简单地委托类。

EDIT1 based on Jon Skeet's answer

但是我如何声明一个公共变量?(非公共变量编译OK)

public interface IModel
{
    double myDouble; <<<< this gives an error
    void Update();
}

public class MyModelA : IModel
{
    public double myDouble;
    public void Update() { ... }
}

public class MyModelB : IModel 
{
    public double myDouble;
    public void Update() { ... }
}
4

2 回答 2

8

不,在这种情况下,您不需要委托 - 您需要一个interface

您创建一个所有类都实现的接口:

public interface IModel
{
    void Update();
}

public class MyModelA : IModel
{
    public void Update() { ... }
}

public class MyModelB : IModel 
{
    public void Update() { ... }
}

然后:

IModel model;
if (x == 1)
{
    model = new MyModelA();
}
else
{
    model = new MyModelB();
}
model.Update();
于 2013-04-10T16:53:19.840 回答
0

作为 Jon Skeet,我认为您需要使用接口。稍微改变了代码

http://www.dotnetperls.com/interface

    using System;

    interface IPerl
    {
        void Read();
    }

    class TestA : IPerl
    {
        public void Read()
        {
        Console.WriteLine("Read TestA");
        }
    }

    class TestB : IPerl
    {
        public void Read()
        {
        Console.WriteLine("Read TestB");
        }
    }

    class Program
    {
        static void Main()
        {
        IPerl perl = new TestA(); // Create instance.
        perl.Read(); // Call method on interface.
        }
    }
于 2013-04-10T17:02:49.403 回答