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

      含有yield的函数说明它是一个生成器,而不是普通的函数。当程序运行到yield这一行时,该函数会返回值,并保存当前域的所有变量状态;等到该函数下一次被调用时,会从上一次中断的地方开始执行,一直遇到下一个yield, 程序返回值, 并在此保存当前状态; 如此反复,直到函数正常执行完成。
      .net里面的迭代器模式  yield return。
      迭代器模式是设计模式中行为模式(behavioral pattern)的一个例子,他是一种简化对象间通讯的模式,也是一种非常容易理解和使用的模式。简单来说,迭代器模式使得你能够获取到序列中的所有元素而不用关心是其类型是array,list,linked list或者是其他什么序列结构。这一点使得能够非常高效的构建数据处理通道(data pipeline)--即数据能够进入处理通道,进行一系列的变换,或者过滤,然后得到结果。事实上,这正是LINQ的核心模式。

      在.NET中,迭代器模式被IEnumerator和IEnumerable及其对应的泛型接口所封装。如果一个类实现了IEnumerable接 口,那么就能够被迭代;调用GetEnumerator方法将返回IEnumerator接口的实现,它就是迭代器本身。迭代器类似数据库中的游标,他是数据序列中的一个位置记录。迭代器只能向前移动,同一数据序列中可以有多个迭代器同时对数据进行操作。

      代码调试查看

     1  public class YieldTest
     2     {
     3         public IEnumerable<int> CreateEnumerable()
     4         {
     5             try
     6             {
     7                 Console.WriteLine("{0} CreateEnumerable()方法开始", DateTime.Now);
     8                 for (int i = 0; i < 5; i++)
     9                 {
    10                     Console.WriteLine("{0}开始 yield {1}", DateTime.Now, i);
    11                     yield return i;
    12                     Console.WriteLine("{0}yield 结束", DateTime.Now);
    13                     if (i == 4)
    14                     {
    15                         yield break;//直接终结迭代  4会出现的,,
    16                     }
    17                 }
    18                 Console.WriteLine("{0} Yielding最后一个值", DateTime.Now);
    19                 yield return -1;
    20                 Console.WriteLine("{0} CreateEnumerable()方法结束", DateTime.Now);
    21             }
    22             finally
    23             {
    24                 Console.WriteLine("停止迭代!");
    25             }
    26         }
    27 
    28         /// <summary>
    29         /// MoveNext 检查是否存在  并设置current
    30         /// </summary>
    31         public void Show()
    32         {
    33             IEnumerable<int> iterable = this.CreateEnumerable();//1 不会直接执行
    34             //IEnumerator iterator = iterable.GetEnumerator();
    35             IEnumerator<int> iterator = iterable.GetEnumerator();
    36             Console.WriteLine("开始迭代");
    37             while (true)
    38             {
    39                 Console.WriteLine("调用MoveNext方法……");
    40                 Boolean result = iterator.MoveNext();//2 正式开启CreateEnumerable
    41                 Console.WriteLine("MoveNext方法返回的{0}", result);
    42                 if (!result)
    43                 {
    44                     break;
    45                 }
    46                 Console.WriteLine("获取当前值……");
    47                 Console.WriteLine("获取到的当前值为{0}", iterator.Current);
    48             }
    49         }
    50     }
    1   class Program
    2     {
    3         static void Main(string[] args)
    4         {
    5             YieldTest yieldTest= new YieldTest ();
    6             yieldTest.Show();
    7             Console.Read();
    8         }
    9     }

    运行结果:

  • 相关阅读:
    Mysql的select加锁分析
    浅析Kubernetes的工作原理
    HTTP/2部署使用
    Amazon新一代云端关系数据库Aurora
    为什么 kubernetes 天然适合微服务
    深入解读Service Mesh背后的技术细节
    微服务的接入层设计与动静资源隔离
    Prim算法和Kruskal算法介绍
    DAG及拓扑排序
    BFS和DFS
  • 原文地址:https://www.cnblogs.com/VueDi/p/13693956.html
Copyright © 2011-2022 走看看