关于泛型类型的IronPython重载决策

前端之家收集整理的这篇文章主要介绍了关于泛型类型的IronPython重载决策前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个带有重载静态方法的C#类,如下所示:
// Added to the Simple class in Tutorial\Extend\csextend.cs
public static int Foo(IEnumerable<int> values)
{
    return 1;
}

public static int Foo(IEnumerable<string> values)
{
    return 2;
}

当我尝试从IronPython 2.6中调用它们时出错.我正在传递一个包含字符串的python列表.

import clr
clr.AddReferenceToFile("csextend.dll")
import Simple

Simple.Foo(["alpha","bravo","charlie"])
TypeError: Multiple targets could match: Foo(IEnumerable[str]),Foo(IEnumerable[
int])

我的第一个问题是为什么这不起作用?似乎重载解决方案应该对此起作用.这是IronPython中的错误吗?什么是最干净的解决方法.我可以重命名例程,这样它们就不会相互重载,但后来我让铁心怪怪改变了C#类的设计.

是否有一种干净的方法可以给python一个线索,即列表完全由一种类型组成,它应该选择一个特定的重载?

this question有关

解决方法

IronPython并没有真正的函数重载,只有一个函数具有所有功能.通常IronPython会自动执行此操作,但泛型类型会使事情变得复杂.要消除使用哪个重载的歧义,使用Overloads字典获取函数,将签名中的类型作为键传递. (我在撰写本文时使用的是IronPython 2.7,因此我不知道版本2.6和2.7之间是否存在差异)
import System.Collections.Generic.IEnumerable as IEnumerable
Simple.Foo.Overloads[IEnumerable[str]](["alpha","charlie"])

如果函数中有更多参数,则将类型作为元组传递.

#public static int Foo(IEnumerable<string> values,string otherParam)
#{
#    return 3;
#}

Simple.Foo.Overloads[IEnumerable[str],str](["alpha","charlie"],"x")

等等

猜你在找的Python相关文章