我正在编写一个序列化程序,我想在其中广泛使用方法重载,序列化派生自 的类型的对象IEnumerable<T>
等等IDictionary<K,V>
。
我还打算使用dynamic
关键字让 CLR 根据要序列化的对象的运行时类型选择正确的重载。
看看这个代码片段:
void Serialize<TKey, TValue>(IDictionary<TKey, TValue> dictionary)
{
Console.WriteLine("IDictionary<TKey, TValue>");
}
void Serialize<TKey, TValue>(IEnumerable<KeyValuePair<TKey, TValue>> items)
{
Console.WriteLine("IEnumerable<KeyValuePair<TKey, TValue>>");
}
void Serialize<T>(IEnumerable<T> items)
{
Console.WriteLine("IEnumerable<T>");
}
我想这样做:
void CallSerialize(object obj)
{
Serialize(obj as dynamic); //let the CLR resolve it at runtime.
}
现在基于 的运行时类型obj
,将调用正确的重载。例如,
//Test code
CallSerialize(new List<int>()); //prints IEnumerable<T>
在这种情况下,调用了第三个重载,其基本原理非常简单:这只是可行的选择。
但是,如果我这样做:
CallSerialize(new Dictionary<int,int>()); //prints IDictionary<TKey, TValue>
它调用第一个重载。我不完全明白这一点。当所有三个重载都是可行的选项时,为什么它会解决第一个重载?
事实上,如果我删除第一个重载,则调用第二个重载,如果我删除第一个和第二个重载,则调用第三个重载。
解决方法重载的优先规则是什么?