【问题标题】:How to determine derived class at run time and allow call to polymorphic method如何在运行时确定派生类并允许调用多态方法
【发布时间】:2014-01-26 05:30:34
【问题描述】:

我有一个接受两个基类参数的函数。在这个函数中,我希望在许多派生类上测试这些参数的类型,然后调用一个多态函数。请参阅下文以查看我的第一次尝试,它不会编译。

    public static double Intersect(baseClass s0, baseClass s1)
    {
          if (s1 is derivedClassB) return (s0 as derivedClassA).PolyMethod((derivedClassB)s1);

          else if (s1 is derivedClassC) return (s0 as  derivedClassA).PolyMethod((derivedClassC)s1);
                    else return 0.0;

    }

我想我可以使用类似的东西

Type dType = s0.GetType();
(s0 as dType).PolyMethod(derivedClassB) s1);

但这也不起作用。

【问题讨论】:

  • 请正确格式化您的代码。
  • 抱歉,我尝试简化时出了点问题……现在认为它的格式没问题
  • 有什么理由不使用 C# 中对多态方法的内置支持? virtual 关键字?
  • 我在基类的 PolyMethod 定义中使用了 virtual ......这只是我用来处理不同类型的单次使用静态方法中的一个问题。我正在为 PolyMethod 使用 virtual 和覆盖

标签: c# polymorphism derived-class


【解决方案1】:

像这样定义你的基类

public abstract BaseClass
{
    public abstract double PolyMethod(BaseClass s);
}

这样定义派生类

public DerviedClassX : BaseClass
{
    public override double PolyMethod(BaseClass s)
    {
        return 0.0; // Return something usefull here.
    }
}

那么你的方法可以这样简化

public static double Intersect(BaseClass s0, BaseClass s1)
{
    return s0.PolyMethod(s1);
}

【讨论】:

  • 我不确定您在这里要做什么,但是这个SO answer on virtual dispatch 以及那里提供给 Eric Lippers arcticle on double dispatch 的链接可能会对您有所帮助。
  • 谢谢...只要你知道怎么做就可以了。
  • 不,这就是我要找的……事实上,我的示例比我在这里介绍的要复杂一些,但我只是感到困惑,因为我有两个参数因类型而异。事实上,它只是简单地归结为现在可以正常工作。
  • 好的。一张便条。你也可以使用virtual 方法而不是abstract 方法,前提是基类可以提供该方法的有用基实现。
  • 谢谢,是的,在这种情况下它不能。我还意识到我什至不需要这个静态方法我可以只使用 s0.PolyMethod(s1) 并为不同的(派生类)参数 s1 提供不同的方法。
猜你喜欢
  • 2015-12-17
  • 2013-05-30
  • 1970-01-01
  • 2021-04-14
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-05-24
  • 2020-04-01
相关资源
最近更新 更多