c# – 通过覆盖链的IEnumerable列表

前端之家收集整理的这篇文章主要介绍了c# – 通过覆盖链的IEnumerable列表前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
好的,很难说这个问题的确切标题,但这里…我有一个抽象的类叫做Block,看起来像这样:
  1. public abstract class Block
  2. {
  3. public bool Enabled{get; private set;}
  4.  
  5. public virtual IEnumerable<KeyValuePair<string,string>> GetDefaultUsages()
  6. {
  7. yield return new KeyValuePair<string,string>("Enabled","true");
  8. }
  9. }

说我有一个子类:

  1. public class Form : Block
  2. {
  3. public string Key{get; private set;}
  4.  
  5. public override IEnumerable<KeyValuePair<string,string>> GetDefaultUsages()
  6. {
  7. yield return new KeyValuePair<string,string>("Key",string.Empty);
  8.  
  9. // can't do: yield return base.GetDefaultUsages()
  10. }
  11. }

这个想法是,GetDefaultUsages()将始终返回一个IEnumerable,其中包含通过整个继承链指定的所有字符串,字符串对.我最初希望yield关键字将支持如下语句:

  1. yield return (some IEnumerable<T> object);

但显然这不行.我意识到我可以做到:

  1. foreach(KeyValuePair<string,string> kv in base.GetDefaultUsages())
  2. {
  3. yield return kv;
  4. }

但是我希望有一个稍微清洁的语法(并避免创建所有不必要的中间IEnumerators).

任何人都有一个很好的方法实现这个想法?

解决方法

你必须像foreach方法那样做,因为base.GetDefaultUsages()返回一个IEnumerable.收益回报处理单项,而不是收藏.尽管如果yield返回可以返回一个对象的集合,那将是很好的.

2周前,约翰·奥克斯利(John Oxley)要求一个similar question.

编辑:
似乎Bart Jacobs,Eric Meyer,Frank Piessens和Wolfram Schulte已经写了a very interesting paper关于他们称之为嵌套迭代器的东西,这基本上是你要求的.

猜你在找的C#相关文章