我不明白为什么永远不会为方法调用方法Value(string s)
列表传递到List<string>
方法时的ToString<M>(List<M> list)
。下面是我从LinqPad中提取的测试代码。
在迭代Value()
方法之外的列表时调用正确的ToString<M>(List<M> list)
方法没有问题。
谢谢!
void Main()
{
var list1 = new List<string>{"one","two","three"};
var list2 = new List<object>{1,2,3};
var list3 = new List<long>{1,2,3};
"Strings".Dump();
ToString<string>(list1);
//list1.ForEach(i=> Value(i)); // proper overload of Value() is called
"Objects".Dump();
ToString<object>(list2);
//list2.ForEach(i=> Value(i));
"Longs".Dump();
ToString<long>(list3);
//list3.ForEach(i=> Value(i));
}
public static string ToString<M>(List<M> list)
{
var sb = new StringBuilder();
foreach(M i in list)
{
sb.AppendFormat("{0},", Value(i));
}
var str = sb.ToString();
str.Dump();
return str;
}
public static string Value(string s)
{
"String".Dump();
return "'" + s + "'";
}
// Define other methods and classes here
public static string Value(object o)
{
"Object".Dump();
return o.ToString();
}
这是输出。它表明从不调用Value(字符串s)
Strings
Object
Object
Object
one,two,three,
Objects
Object
Object
Object
1,2,3,
Longs
Object
Object
Object
1,2,3,
答案 0 :(得分:6)
因为Value()
中ToString<M>
的绑定是在编译时完成的。由于M
没有约束,因此可以找到的最佳重载是Value(object)
。
要绑定到Value(string)
,您必须将参数转换为string
或在i
循环中生成dynamic
foreach
:
foreach(dynamic i in list)
{
sb.AppendFormat("{0},", Value(i));
}
然后,它会在运行时绑定Value(i)
,然后选择是使用string
还是object
重载。