2) LINQ编程技术内幕--yield return
yield return 使用.NET的状态机生成器
yield return关键词组自动实现IDisposable,使用这个可枚举的地方, 还存在一个隐含的try finally块. 示例代码:
classProgram{staticvoidMain(string[] args){foreach(int i inGetEvents()){Console.WriteLine(i);}Console.ReadLine();}staticIEnumerable<int>GetEvents(){var integers =new[]{1,2,3,4,5,6,7,8};foreach(int i in integers){if(i%2==0){yieldreturn i;//返回了一个可迭代对象[2,4,6,8].}}}}
yield return意味着可以在任何对象上获得可枚举功能, 而无需编写类型化集合类以及相关的处理代码.
- 一个关于
yield return和yield break(在得到需要的遍历之前而中止的过程. 已中序遍历为例:
publicclassNode<T>where T:IComparable<T>{public T data;privateNode<T> leftNode;publicNode<T>LeftNode{get;set;}privateNode<T> rightNode;publicNode<T>RightNode{get;set;}publicNode(T data){this.data = data;}publicoverridestringToString(){return data.ToString();}}publicclassBinaryTreeNode<T>where T:IComparable<T>{privateNode<T> root;publicNode<T>Root{get;set;}publicvoidAdd(T item){if(root ==null){root =newNode<T>(item);return;}Add(item, root);}privatevoidAdd(T item,Node<T> node){if(item.CompareTo(node.data)<0){if(node.LeftNode==null)node.LeftNode=newNode<T>(item);elseAdd(item, node.LeftNode);}elseif(item.CompareTo(node.data)>0){if(node.RightNode==null)node.RightNode=newNode<T>(item);else{Add(item, node.RightNode);}}}publicvoidAddRange(params T[] items){foreach(var item in items){Add(item);}}publicvoidPrint(){Print(root,0,Console.WindowWidth/2);}publicIEnumerable<T>Inorder{get{returnGetInOrder(this.root);}}int depth =0;/// <summary>/// 中序遍历: 左 根 右/// </summary>/// <param name="node"></param>/// <returns></returns>privateIEnumerable<T>GetInOrder(Node<T> node){//if (depth++ > 4) yield break;//大于4层,则只输出前4层.!!!这块待确认.if(node.LeftNode!=null){foreach(T item inGetInOrder(node.LeftNode)){yieldreturn item;}}yieldreturn node.data;if(node.RightNode!=null){foreach(T item inGetInOrder(node.RightNode)){yieldreturn item;}}}privatevoidPrint(Node<T> item,int depth,int offset){if(item ==null)return;Console.CursorLeft= offset;Console.CursorTop= depth;Console.Write(item.data);if(item.LeftNode!=null)Print("/", depth +1, offset -1);Print(item.LeftNode, depth +2, offset -3);if(item.RightNode!=null)Print("\\", depth +1, offset +1);Print(item.RightNode, depth +2, offset +3);}privatevoidPrint(string s,int depth,int offset){Console.CursorLeft= offset;Console.CursorTop= depth;Console.Write(s);}}classProgram{staticvoidMain(string[] args){BinaryTreeNode<int> integers =newBinaryTreeNode<int>();integers.AddRange(8,5,6,7,3,4,13,21,1,17);integers.Print();Console.ReadLine();Console.Clear();foreach(var item in integers.Inorder){Console.WriteLine(item);}Console.ReadLine();}}
2) LINQ编程技术内幕--yield return的更多相关文章
- Java并发编程与技术内幕:线程池深入理解
摘要: 本文主要讲了Java当中的线程池的使用方法.注意事项及其实现源码实现原理,并辅以实例加以说明,对加深Java线程池的理解有很大的帮助. 首先,讲讲什么是线程池?照笔者的简单理解,其实就是一组线 ...
- 《[MySQL技术内幕:SQL编程》读书笔记
<[MySQL技术内幕:SQL编程>读书笔记 2019年3月31日23:12:11 严禁转载!!! <MySQL技术内幕:SQL编程>这本书是我比较喜欢的一位国内作者姜承尧, ...
- 《MSSQL2008技术内幕:T-SQL语言基础》读书笔记(下)
索引: 一.SQL Server的体系结构 二.查询 三.表表达式 四.集合运算 五.透视.逆透视及分组 六.数据修改 七.事务和并发 八.可编程对象 五.透视.逆透视及分组 5.1 透视 所谓透视( ...
- 《MSSQL2008技术内幕:T-SQL语言基础》读书笔记(上)
索引: 一.SQL Server的体系结构 二.查询 三.表表达式 四.集合运算 五.透视.逆透视及分组 六.数据修改 七.事务和并发 八.可编程对象 一.SQL Server体系结构 1.1 数据库 ...
- 【转】COM技术内幕(笔记)
COM技术内幕(笔记) COM--到底是什么?--COM标准的要点介绍,它被设计用来解决什么问题?基本元素的定义--COM术语以及这些术语的含义.使用和处理COM对象--如何创建.使用和销毁COM对象 ...
- 深入理解linux网络技术内幕读书笔记(三)--用户空间与内核的接口
Table of Contents 1 概论 1.1 procfs (/proc 文件系统) 1.1.1 编程接口 1.2 sysctl (/proc/sys目录) 1.2.1 编程接口 1.3 sy ...
- MFC技术内幕系列之(四)---MFC消息映射与消息传递内幕
//////////////////////////////////////////////////////////////////////////////////// ...
- 2008技术内幕:T-SQL语言基础
2008技术内幕:T-SQL语言基础 单表查询摘记 这里的摘抄来自<Microsoft SQL Server 2008技术内幕:T-SQL语言基础>,书中用到的案例数据库是这个 TSQLF ...
- 2008技术内幕:T-SQL语言基础 单表查询摘记
这里的摘抄来自<Microsoft SQL Server 2008技术内幕:T-SQL语言基础>,书中用到的案例数据库是这个 TSQLFundamentals2008 ,官网给出的连接是这 ...
随机推荐
- CALayer精讲
前言 CALayer包含在QuartzCore框架中,这是一个跨平台的框架,既可以用在iOS中又可以用在Mac OS X中.后面要学Core Animation就应该先学好Layer(层). 我们看一 ...
- 转载 https协议和http协议的区别
转载原地址: http://aajs800.blog.51cto.com/519255/109555 什么是HTTPS: HTTPS(Secure Hypertext Transfer Protoco ...
- emWin -- 模拟器系列1 - 如何建立模拟器开发环境
面对如此强大的emWin,大家是否都有跃跃欲试的冲动呢?但是没有硬件可以调试的童鞋,难道只能望洋兴叹?非也.非也.Segger公司早就考虑到了.Segger推出模拟器的目的不仅仅是为了解决没有硬件的烦 ...
- vss2005使用
http://www.cnblogs.com/nianyuwen/archive/2012/06/13/2547588.html 签出状态的文件别人无法使用:
- Oracle- 包
在一个大型项目中,可能有很多模块,而每个模块又有自己的过程.函数等.而这些过程.函数默认是放在一起的(如在PL/SQL中,过程默认都是放在一起的,即Procedures中),这些非常不方便查询和维护. ...
- html样式表极大地提高了工作效率
样式表极大地提高了工作效率 样式表定义如何显示 HTML 元素,就像 HTML 3.2 的字体标签和颜色属性所起的作用那样.样式通常保存在外部的 .css 文件中.通过仅仅编辑一个简单的 CSS 文档 ...
- Android最新锁屏病毒分析及解锁
一.情况简介 从去年开始PC端的敲诈者类病毒在不断的爆发,今年年初的时候手机上也开始出现了敲诈者之类的病毒,对这类病毒很无语也是趋势,因为很多时候病毒的产生是和金钱利益相关的.前天去吾爱破解论坛病 ...
- 友盟分享 -QQAPI- QQApi.m:250 param error: url is nil
有一个项目 需要用到友盟分享,点击分享内容,需要跳转到指定的url,不带参数的url非常好跳,也没什么问题,但是 带了参数之后:比如http://121.43.121.8:8080/tj/photo/ ...
- linux tomca几个配置文件及点
--------------------推荐----配置2---------------------<Connector port="8081"executor=" ...
- iOS开发:AVPlayer实现流音频边播边存
1. AVPlayer简介 AVPlayer存在于AVFoundation中,可以播放视频和音频,可以理解为一个随身听 AVPlayer的关联类: AVAsset:一个抽象类,不能直接使用,代表一个要 ...