繁体   English   中英

返回不同泛型集合的泛型方法

[英]Generic Method returning different generic collections

嗨我有这样的方法:

        public T LoadR<T, K>()
        where T : ObservableCollection<K>, new()
        where K : IStoreElement, new() {
        T onC = new T();
        //....
        return (onC);
    }

此外,我有一个XObservableCollection类,它派生自ObservableCollection。 当我打电话时,它的工作原理是:

Categories = LoadR<ObservableCollection<Category>,Category>();
Products = LoadR<XObservableCollection<Product>,Product>();

我想要做的就是这样做一个调用(避免将K作为额外参数传递):

Categories = LoadR<ObservableCollection<Category>>();
Products = LoadR<XObservableCollection<Product>>();

我知道我可以为它写一个扩展名。 但我很好奇是否有办法在没有它的情况下实现这一目标。

曼弗雷德

我认为你不能。

C#有一种机制来理解方法参数中使用的泛型agruments,而不是来自同一方法的其他泛型参数。 它不起作用。

也许您可以将签名更改为:

    private static ObservableCollection<K> LoadR<K>(.ObservableCollection<K> onC)
        where K : IStoreElement, new()
    {
        //....
        return onC;
    }

用法是:

    static void TestLoad()
    {
        var result1 = LoadR(new ObservableCollection<Something>());
        var result2 = LoadR(new DerivedClassFromObservableCollection<Something>());
    }

我同意的不是那么好,我可以认为它不是你想要的。

但只是因为C# 不会让你尝试从泛型参数中推断出类型。

.....

另一种方式是使它使用特定的集合。 我可以看到你不想要这个。

所以,你可以做的一件事是让它返回IEnumerable,然后你的用法将是这样的:

    static void TestLoad()
    {
        var result1 = new ObservableCollection( LoadR<Something>() );
        var result1 = new DerivedClassFromObservableCollection( LoadR<Something>() );
    }

如果你想用收藏本身做一些奇特的东西,那也许不好,因为你不再拥有它。

....

我自己会选择第一个选项。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM