[我正在尝试为类型为Dictionary<TKey, IEnumerable<TValue>>
的字典编写通用扩展方法,该方法应为给定键返回IEnumerable<TValue>
的实例,如果该键尚无条目,请创建一个新的IEnumerable<TValue>
实例]并为该键添加它。
public static TEnumerable GetAndEnsureEnumerableForKey<TKey, TValue, TEnumerable>(
this Dictionary<TKey, TEnumerable> dictionary, TKey key)
where TEnumerable : IEnumerable<TValue>
{
TEnumerable enumerableForKey;
if (!dictionary.TryGetValue(key, out enumerableForKey))
{
Type enumerableType = typeof(TEnumerable);
enumerableForKey = (TEnumerable)Activator.CreateInstance(enumerableType);
dictionary.Add(key, enumerableForKey);
}
return enumerableForKey;
}
该方法本身可以正常工作,但是我对该方法的调用有疑问。给定Dictionary<int, List<int>> intListDictionary
我希望电话intListDictionary.GetAndEnsureEnumerableForKey(sampleInt);
可以正常工作。但是,编译器抱怨它无法从方法调用中推断类型TValue
,而我将不得不调用intListDictionary.GetAndEnsureEnumerableForKey<int, int, List<int>>(sampleInt);
,这在这种情况下违反了泛型的目的。
[当TValue
被约束为TEnumerable
且我从中调用的具体字典应该知道该类型时,编译器如何无法推断IEnumerable<TValue>
类型?
类型推断仅基于类型实参,而不是类型约束,如this answer中所述。
要实现所需的功能,可以将TEnumerable
的类型约束更改为非通用IEnumerable
接口:
public static TEnumerable GetAndEnsureEnumerableForKey<TKey, TEnumerable>(
this Dictionary<TKey, TEnumerable> dictionary,
TKey key)
where TEnumerable : IEnumerable
{
TEnumerable enumerableForKey;
if (!dictionary.TryGetValue(key, out enumerableForKey))
{
Type enumerableType = typeof(TEnumerable);
enumerableForKey = (TEnumerable)Activator.CreateInstance(enumerableType);
dictionary.Add(key, enumerableForKey);
}
return enumerableForKey;
}
您需要添加System.Collections
以使IEnumerable
界面可访问。