yield return 使用.NET的状态机生成器

  • yield return关键词组自动实现IDisposable,使用这个可枚举的地方, 还存在一个隐含的try finally块. 示例代码:
  1. classProgram
  2. {
  3. staticvoidMain(string[] args)
  4. {
  5. foreach(int i inGetEvents())
  6. {
  7. Console.WriteLine(i);
  8. }
  9. Console.ReadLine();
  10. }
  11. staticIEnumerable<int>GetEvents()
  12. {
  13. var integers =new[]{1,2,3,4,5,6,7,8};
  14. foreach(int i in integers)
  15. {
  16. if(i%2==0)
  17. {
  18. yieldreturn i;//返回了一个可迭代对象[2,4,6,8].
  19. }
  20. }
  21. }
  22. }

yield return意味着可以在任何对象上获得可枚举功能, 而无需编写类型化集合类以及相关的处理代码.

  • 一个关于yield returnyield break(在得到需要的遍历之前而中止的过程. 已中序遍历为例:
  1. publicclassNode<T>where T:IComparable<T>
  2. {
  3. public T data;
  4. privateNode<T> leftNode;
  5. publicNode<T>LeftNode{get;set;}
  6. privateNode<T> rightNode;
  7. publicNode<T>RightNode{get;set;}
  8. publicNode(T data)
  9. {
  10. this.data = data;
  11. }
  12. publicoverridestringToString()
  13. {
  14. return data.ToString();
  15. }
  16. }
  17. publicclassBinaryTreeNode<T>where T:IComparable<T>
  18. {
  19. privateNode<T> root;
  20. publicNode<T>Root{get;set;}
  21. publicvoidAdd(T item)
  22. {
  23. if(root ==null)
  24. {
  25. root =newNode<T>(item);
  26. return;
  27. }
  28. Add(item, root);
  29. }
  30. privatevoidAdd(T item,Node<T> node)
  31. {
  32. if(item.CompareTo(node.data)<0)
  33. {
  34. if(node.LeftNode==null)
  35. node.LeftNode=newNode<T>(item);
  36. else
  37. Add(item, node.LeftNode);
  38. }
  39. elseif(item.CompareTo(node.data)>0)
  40. {
  41. if(node.RightNode==null)
  42. node.RightNode=newNode<T>(item);
  43. else
  44. {
  45. Add(item, node.RightNode);
  46. }
  47. }
  48. }
  49. publicvoidAddRange(params T[] items)
  50. {
  51. foreach(var item in items)
  52. {
  53. Add(item);
  54. }
  55. }
  56. publicvoidPrint()
  57. {
  58. Print(root,0,Console.WindowWidth/2);
  59. }
  60. publicIEnumerable<T>Inorder
  61. {
  62. get{returnGetInOrder(this.root);}
  63. }
  64. int depth =0;
  65. /// <summary>
  66. /// 中序遍历: 左 根 右
  67. /// </summary>
  68. /// <param name="node"></param>
  69. /// <returns></returns>
  70. privateIEnumerable<T>GetInOrder(Node<T> node)
  71. {
  72. //if (depth++ > 4) yield break;//大于4层,则只输出前4层.!!!这块待确认.
  73. if(node.LeftNode!=null)
  74. {
  75. foreach(T item inGetInOrder(node.LeftNode))
  76. {
  77. yieldreturn item;
  78. }
  79. }
  80. yieldreturn node.data;
  81. if(node.RightNode!=null)
  82. {
  83. foreach(T item inGetInOrder(node.RightNode))
  84. {
  85. yieldreturn item;
  86. }
  87. }
  88. }
  89. privatevoidPrint(Node<T> item,int depth,int offset)
  90. {
  91. if(item ==null)return;
  92. Console.CursorLeft= offset;
  93. Console.CursorTop= depth;
  94. Console.Write(item.data);
  95. if(item.LeftNode!=null)
  96. Print("/", depth +1, offset -1);
  97. Print(item.LeftNode, depth +2, offset -3);
  98. if(item.RightNode!=null)
  99. Print("\\", depth +1, offset +1);
  100. Print(item.RightNode, depth +2, offset +3);
  101. }
  102. privatevoidPrint(string s,int depth,int offset)
  103. {
  104. Console.CursorLeft= offset;
  105. Console.CursorTop= depth;
  106. Console.Write(s);
  107. }
  108. }
  109. classProgram
  110. {
  111. staticvoidMain(string[] args)
  112. {
  113. BinaryTreeNode<int> integers =newBinaryTreeNode<int>();
  114. integers.AddRange(8,5,6,7,3,4,13,21,1,17);
  115. integers.Print();
  116. Console.ReadLine();
  117. Console.Clear();
  118. foreach(var item in integers.Inorder)
  119. {
  120. Console.WriteLine(item);
  121. }
  122. Console.ReadLine();
  123. }
  124. }

2) LINQ编程技术内幕--yield return的更多相关文章

  1. Java并发编程与技术内幕:线程池深入理解

    摘要: 本文主要讲了Java当中的线程池的使用方法.注意事项及其实现源码实现原理,并辅以实例加以说明,对加深Java线程池的理解有很大的帮助. 首先,讲讲什么是线程池?照笔者的简单理解,其实就是一组线 ...

  2. 《[MySQL技术内幕:SQL编程》读书笔记

    <[MySQL技术内幕:SQL编程>读书笔记 2019年3月31日23:12:11 严禁转载!!! <MySQL技术内幕:SQL编程>这本书是我比较喜欢的一位国内作者姜承尧, ...

  3. 《MSSQL2008技术内幕:T-SQL语言基础》读书笔记(下)

    索引: 一.SQL Server的体系结构 二.查询 三.表表达式 四.集合运算 五.透视.逆透视及分组 六.数据修改 七.事务和并发 八.可编程对象 五.透视.逆透视及分组 5.1 透视 所谓透视( ...

  4. 《MSSQL2008技术内幕:T-SQL语言基础》读书笔记(上)

    索引: 一.SQL Server的体系结构 二.查询 三.表表达式 四.集合运算 五.透视.逆透视及分组 六.数据修改 七.事务和并发 八.可编程对象 一.SQL Server体系结构 1.1 数据库 ...

  5. 【转】COM技术内幕(笔记)

    COM技术内幕(笔记) COM--到底是什么?--COM标准的要点介绍,它被设计用来解决什么问题?基本元素的定义--COM术语以及这些术语的含义.使用和处理COM对象--如何创建.使用和销毁COM对象 ...

  6. 深入理解linux网络技术内幕读书笔记(三)--用户空间与内核的接口

    Table of Contents 1 概论 1.1 procfs (/proc 文件系统) 1.1.1 编程接口 1.2 sysctl (/proc/sys目录) 1.2.1 编程接口 1.3 sy ...

  7. MFC技术内幕系列之(四)---MFC消息映射与消息传递内幕

    ////////////////////////////////////////////////////////////////////////////////////                 ...

  8. 2008技术内幕:T-SQL语言基础

    2008技术内幕:T-SQL语言基础 单表查询摘记 这里的摘抄来自<Microsoft SQL Server 2008技术内幕:T-SQL语言基础>,书中用到的案例数据库是这个 TSQLF ...

  9. 2008技术内幕:T-SQL语言基础 单表查询摘记

    这里的摘抄来自<Microsoft SQL Server 2008技术内幕:T-SQL语言基础>,书中用到的案例数据库是这个 TSQLFundamentals2008 ,官网给出的连接是这 ...

随机推荐

  1. C++学习笔记(八):函数重载、函数指针和函数对象

    函数重载 函数重载是指在同一作用域内,可以有一组具有相同函数名,不同参数列表的函数,这组函数被称为重载函数.重载函数通常用来命名一组功能相似的函数,这样做减少了函数名的数量,避免了名字空间的污染,对于 ...

  2. SD卡fat文件系统移植

    经过充分的研究,发现fatfs文件系统移植的比较简单!因为代码都已经被别人做好了!我们只需把io层稍稍做个处理就ok了: 至于sd卡的驱动请看我这篇博客:http://blog.csdn.net/ie ...

  3. 退出程序是跳过屏幕自检 比如 必输 EXIT-COMMAND

    控制必须输入可以,但是我退出程序的时候还要求我输入个值才能退出,这太变态了,相信很多同志都在SAP程序中反感过这个问题. 标准程序咱就不说了,忍了,新开发的功能还是要解决这个问题. 办法很简单:MOD ...

  4. 在与SQL Server建立连接时出现与网络相关的或特定于实例的错误

    向往前一样.学习牛腩新闻公布系统的视频,写程序,打开数据库.出现一个框框,具体内容例如以下: 数据库连接不上.全部的工作都要歇班,捣鼓了会儿,简单总结一下解决该问题的方法. 首先:第一步,程序--SQ ...

  5. ListOrderedMap

    要有序能够用List,要便于查找能够用Map,那既要有序又便于查找呢? 近期我就遇到了这样一个问题.Java没有给我们提供现成的类.我们全然能够自己开发个类继承List和Map(Java原来就有不能够 ...

  6. 【20】宁以pass-by-reference-to-const替换pass-by-value

    1.首先理解需求,被调用方法修改了形参,如果期望在主调方法中的实参也发生变化,必须使用pass-by-reference.因为C++缺省情况下(继承C方式),以by-value传递对象,在被调方法中修 ...

  7. JS字符处理

    JS取整 1.toFixed(num)(ps:num为保留小数点后几位) 自定义保留小数点后几位,进行四舍五入.严格来说,这个函数不属于取整,但是当num=0时,也就是取整了,所以一起放到这里,方便查 ...

  8. Oracle Hints具体解释

    在向大家具体介绍Oracle Hints之前,首先让大家了解下Oracle Hints是什么,然后全面介绍Oracle Hints,希望对大家实用.基于代价的优化器是非常聪明的,在绝大多数情况下它会选 ...

  9. android学习日记28--Android中常用设计模式总结

    一.综述 设计模式,根据前人经验总结出常见软件工程问题的解决思想套路.GoF一共归纳了23种设计模式,当然还有人扩充,不止这些.设计模式主要利用面向对象语言的特性,而android 的设计主要用JAV ...

  10. Struts2中的类型转换

    1.     Struts2中的类型转换 我们知道通过HTTP提交到后台的数据,都是字符串的形式,而我们需要的数据类型当然不只字符串类型一种.所以,我们需要类型转换! 在Struts2中,类型转换的概 ...