zoukankan      html  css  js  c++  java
  • C#中的yield关键字

    2010-12-27 09:23:10|  分类: .NET编程 |  标签: |字号 订阅

     
     
    yield   
        关键字yield:在迭代器块中用于向枚举数对象提供值或发出迭代结束信号。迭代器块有两个特殊语句:    
              ●yield return <expression_r_r_r_r>;    
              ●yield break;
      迭代器块   
        迭代器块是有一个或多个yield语句的代码块。下面三种类型的代码块中的任意一种都可以是迭代器块:    
              ■方法主体    
              ■访问器主体    
              ■运算符主体
      yield语句只能出现在迭代器块中,该块可用作方法、运算符或访问器的体。这类方法、运算符或访问器的体受以下约束的控制:   
            ■不允许不安全块。    
            ■方法、运算符或访问器的参数不能是 ref 或 out。    
            ■yield语句不能出现在匿名方法中。    
            ■yield return语句不能出现在catch 块中或含有一个或多个catch子句的try块中。
          yield语句的迭代块可以产生IEnumerator和IEnumerable两种对象:   
    ★IEnumerable对象:    
    public IEnumerable<int> GetInts()    
            {    
    yield return 0;    
    yield return 1;    
    yield return 2;    
    yield return 3;    
            }    
        使用示例:直接作用在foreach语句中    
    foreach (int i in GetInts())    
            {    
                Console.WriteLine(i.ToString());    
            }    
    ★IEnumerator对象:    
    public IEnumerator<int> GetEnumerator()//注意方法名    
            {    
    yield return 0;    
    yield return 1;    
    yield return 2;    
    yield return 3;    
            }    
        使用示例1:无法直接用于foreach语句,获取迭代器的方法名可任意选择,如MyEnumerator().    
            Integers ints = new Integers();//Integers是GetEnumerator()方法所在的类。    
            IEnumerator<int> enumerator = ints.GetEnumerators();    
    while (enumerator.MoveNext())    
            {    
                Console.WriteLine(enumerator.Current.ToString());    
            }    
        使用示例2:可以作用于foreach语句,但是是方法所在的类用在foreach语句中,并且必须使用GetEnumerator作为获取迭代器的方法名。    
            Integers ints = new Integers();//Integers是GetEnumerator()方法所在的类。    
    foreach (int i in ints)    
            {    
                Console.WriteLine(i.ToString());    
            }
  • 相关阅读:
    2018年年终总结
    oracle存储过程 关于update的动态SQL-工作心得
    编译+远程调试spark
    记录一次 hadoop yarn resourceManager无故切换的故障
    hadoop2.8.4 版本yarn RM fairScheduler调度性能优化的若干次尝试
    记录一次hadoop2.8.4版本RM接入zk ha问题
    Ranger-hdfs插件压测
    ranger-hdfs 插件组权限测试
    Nginx基本参数调优
    Nginx安装配置
  • 原文地址:https://www.cnblogs.com/zhisong/p/yield.html
Copyright © 2011-2022 走看看