要是本身的類支持foreach ,必須在類中必須有GetEnumerator方法,該方法返回的是一個IEnumerator類型的枚舉器;對象
public class MyStruct { public string[] sName = new string[] { "張三", "李四", "王五" }; public IEnumerator GetEnumerator() { return new MyStructEnumerator(sName); } }
因此本身得寫一個類類繼承IEnumerator接口,並在類中實現IEnumerator接口;blog
public class MyStructEnumerator : IEnumerator { //要遍歷的對象 private string[] sList; public MyStructEnumerator(string[] get) { sList = get; //獲得 } //索引 private int index = -1; //獲取當前項 public object Current { get { if(index>=0&&index<sList.Length) { return sList[index]; } else { throw new IndexOutOfRangeException(); } } } //移到下一個 public bool MoveNext() { if (index+1 < sList.Length) { index++; return true; } else { return false; } } //重置 public void Reset() { index = -1; } }
而後在實例化本身寫的MyStruct就能夠用foreach來遍歷了;繼承
或者更方便的辦法,只需在MyStrcu中添加一個方法;(方法一)索引
public class MyStruct { public string[] sName = new string[] { "張三", "李四", "王五" }; //當返回值類型是IEnumerator時,編譯器會自動幫咱們生成一個「枚舉類」,即實現了IEnumerator的接口的類 public IEnumerable GetObj() { for(int i=0;i<sName.Length;i++) { yield return sName[i]; } } }
而後能夠直接調用foreach(string res in MyStruct.GetObj){...};接口
也能夠(方法2)get
public class MyStruct { public string[] sName = new string[] { "張三", "李四", "王五" }; public IEnumerator GetEnumerator() { for(int i=0;i<sName.Length;i++) { yield return sName[i]; } } }
以後直接調用foreach(string res in MyStruct);比上面的寫法看起來方便在不用再去調用GetObj方法;編譯器
方法一和方法二的區別是一個要調用方法, 方法二不用調用方法是由於類裏有GetEnumerator方法,foreach會認出這個方法,而方法一沒有,因此要。出方法,方法一會自動去實現IEnumerable接口.string