
以前,如果我们希望构建支持foreach枚举的自定义集合,只能实现IEnumerable接口(可能还有IEnumerator()),返回值还必须是IEnumerator类型,除此之外还可以通过迭代器来使用构建foreach循环的类型,详细见下链接。
代码
public class Car { //内部状态数据 public int CurentSpeed; public int MaxSpeed; public string name; //汽车能不能用 private bool carIsdead; //类构造函数 public Car() { } public Car(string name,int currentspeed,int maxspeed = 100) { this.name = name; this.CurentSpeed = currentspeed; this.MaxSpeed = maxspeed; } //定义委托类型 public delegate voID CarEngineHandler(string msdForCar); //定义每个委托类型的成员变量 private CarEngineHandler listofhandlers; //向调用者添加注册函数 public voID RegisterWithCarEngine(CarEngineHandler methodTocall) { if (listofhandlers == null) listofhandlers = methodTocall; else listofhandlers += methodTocall;//支持多路广播 } //实现Accelerate()方法 public voID Accelerate(int delta) { if (carIsdead) { if (listofhandlers != null) { listofhandlers("sorry,this car is dead"); } } else { CurentSpeed += delta; //不能超过最大速度 if (5 == (MaxSpeed - CurentSpeed) && listofhandlers != null) { listofhandlers("this speed is nearly to the maxspeed"); } if (CurentSpeed > MaxSpeed) { carIsdead = true; } else Console.Writeline("current speed:{0}",CurentSpeed); } } } public class Garage : IEnumerable { private Car[] garage = new Car[3]; public Garage() { garage[0] = new Car("a",10); garage[1] = new Car("b",13); garage[2] = new Car("c",14); } public Enumerator GetEnumerator() { //返回数组对象的IEnumerator //return garage.GetEnumerator(); //用yIEld关键字构建迭代器方法 foreach (Car c in garage) { //当yIEld return语句执行后,当前位会被 //保存下来,下一次执行会从当前位开始 yIEld return c; } } } class Program { static voID Main(string[] args) { Garage g = new Garage(); foreach (Car c in g) { Console.Writeline("car name:{0}",c.name); } } }参考:C#中可枚举类型详解
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
总结以上是内存溢出为你收集整理的C#使用yield关键字构建迭代器详解全部内容,希望文章能够帮你解决C#使用yield关键字构建迭代器详解所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)