c# – 如何将ICollection转换为IReadOnlyCollection?
发布时间:2020-12-15 08:17:52 所属栏目:百科 来源:网络整理
导读:当我有一个ICollection T的变量时在C#中,我无法将其传递给期望IReadOnlyCollection T的函数: public void Foo(){ ICollectionint data = new Listint(); // Bar(data); // Not allowed: Cannot implicitly cast ICollectionint to IReadOnlyCollectionint B
当我有一个ICollection< T>的变量时在C#中,我无法将其传递给期望IReadOnlyCollection< T>的函数:
public void Foo() { ICollection<int> data = new List<int>(); // Bar(data); // Not allowed: Cannot implicitly cast ICollection<int> to IReadOnlyCollection<int> Bar(data.ToList()); // Works,since List<T> implements IReadOnlyCollection<T> } public void Bar(IReadOnlyCollection<int> data) { if (data.Count == 1) { /* ... */ } // ... } 显然问题在于ICollection< T>不从IReadOnlyCollection< T>继承- 但为什么?的ICollection< T>应该是IReadOnlyCollection< T>的全功能集合.加上修改集合的功能. 传递参数的最佳解决方案是什么? 一方面,因为我不想改变Bar中的集合,只需要计数并迭代集合,我想要一个IReadOnlyCollection. 另一方面,每次调用该函数时,我都不想创建新的列表对象. 解决方法
没有标准的解决方案AFAIK,但是这样做并不难
public static class MyExtensions { public static IReadOnlyCollection<T> AsReadOnly<T>(this ICollection<T> source) { if (source == null) throw new ArgumentNullException("source"); return source as IReadOnlyCollection<T> ?? new ReadOnlyCollectionAdapter<T>(source); } sealed class ReadOnlyCollectionAdapter<T> : IReadOnlyCollection<T> { readonly ICollection<T> source; public ReadOnlyCollectionAdapter(ICollection<T> source) => this.source = source; public int Count => source.Count; public IEnumerator<T> GetEnumerator() => source.GetEnumerator(); IEnumerator IEnumerable.GetEnumerator() => GetEnumerator(); } } 然后按如下方式使用它 Bar(data.AsReadOnly()); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |