小苏子
小苏子PDF在线图书

深入理解C#(第3版) 内容简介

深入理解C#(第3版) 内容简介

深入理解C#(第3版) 目录

深入理解C#(第3版) 精彩文摘

《深入理解C#(第3版)》是C#领域不可多得的经典著作。作者在详尽地展示C#各个知识点的同时,更注重从现象中挖掘本质。《深入理解C#(第3版)》深入探索了C#的核心概念和经典特性,并将这些特性融入到代码中,让读者能够真正领会到C#之“深入”与“精妙”。在第2版的基础上,《深入理解C#(第3版)》新增了C# 5的新特性——异步,并更新了随着技术的发展,已经不再适用的内容,确保整本书能达到读者期望的高标准。如果你略微了解一点C#,就可无障碍地阅读《深入理解C#(第3版)》。第一部分 基础知识第1章 C#开发的进化史 21.1 从简单的数据类型开始 31.1.1 C# 1中定义的产品类型 31.1.2 C# 2中的强类型集合 41.1.3 C# 3中自动实现的属性 51.1.4 C# 4中的命名实参 61.2 排序和过滤 71.2.1 按名称对产品进行排序 71.2.2 查询集合 101.3 处理未知数据 121.3.1 表示未知的价格 121.3.2 可选参数和默认值 131.4 LINQ简介 141.4.1 查询表达式和进程内查询 141.4.2 查询XML 151.4.3 LINQ to SQL 161.5 COM和动态类型 171.5.1 简化COM互操作 171.5.2 与动态语言互操作 181.6 轻松编写异步代码 191.7 剖析.NET平台 201.7.1 C#语言 201.7.2 运行时 211.7.3 框架库 211.8 怎样写出超炫的代码 221.8.1 采用代码段形式的全能代码 221.8.2 教学代码不是产品代码 231.8.3 你的新朋友:语言规范 231.9 小结 24第2章 C# 1所搭建的核心基础 252.1 委托 252.1.1 简单委托的构成 262.1.2 合并和删除委托 302.1.3 对事件的简单讨论 322.1.4 委托总结 332.2 类型系统的特征 332.2.1 C#在类型系统世界中的位置 342.2.2 C# 1的类型系统何时不够用 362.2.3 类型系统特征总结 392.3 值类型和引用类型 392.3.1 现实世界中的值和引用 392.3.2 值类型和引用类型基础知识 402.3.3 走出误区 412.3.4 装箱和拆箱 432.3.5 值类型和引用类型小结 442.4 C# 1之外:构建于坚实基础之上的新特性 442.4.1 与委托有关的特性 442.4.2 与类型系统有关的特性 462.4.3 与值类型有关的特性 482.5 小结 49第二部分 C# 2:解决C# 1的问题第3章 用泛型实现参数化类型 523.1 为什么需要泛型 533.2 日常使用的简单泛型 543.2.1 通过例子来学习:泛型字典 543.2.2 泛型类型和类型参数 563.2.3 泛型方法和判读泛型声明 593.3 深化与提高 623.3.1 类型约束 623.3.2 泛型方法类型实参的类型推断 673.3.3 实现泛型 683.4 高级泛型 733.4.1 静态字段和静态构造函数 733.4.2 JIT编译器如何处理泛型 753.4.3 泛型迭代 773.4.4 反射和泛型 793.5 泛型在C#和其他语言中的限制 823.5.1 泛型可变性的缺乏 833.5.2 缺乏操作符约束或者“数值”约束 873.5.3 缺乏泛型属性、索引器和其他成员类型 883.5.4 同C++模板的对比 893.5.5 和Java泛型的对比 903.6 小结 91第4章 可空类型 934.1 没有值时怎么办 934.1.1 为什么值类型的变量不能是null 944.1.2 在C# 1中表示空值的模式 944.2 System.Nullable和System.Nullable 964.2.1 Nullable简介 964.2.2 Nullable装箱和拆箱 994.2.3 Nullable实例的相等性 1004.2.4 来自非泛型Nullable类的支持 1014.3 C# 2为可空类型提供的语法糖 1014.3.1 ?修饰符 1024.3.2 使用null进行赋值和比较 1034.3.3 可空转换和操作符 1054.3.4 可空逻辑 1084.3.5 对可空类型使用as操作符 1094.3.6 空合并操作符 1104.4 可空类型的新奇用法 1124.4.1 尝试一个不使用输出参数的操作 1134.4.2 空合并操作符让比较不再痛苦 1154.5 小结 117第5章 进入快速通道的委托 1185.1 向笨拙的委托语法说拜拜 1195.2 方法组转换 1205.3 协变性和逆变性 1225.3.1 委托参数的逆变性 1225.3.2 委托返回类型的协变性 1235.3.3 不兼容的风险 1245.4 使用匿名方法的内联委托操作 1255.4.1 从简单的开始:处理一个参数 1265.4.2 匿名方法的返回值 1285.4.3 忽略委托参数 1295.5 匿名方法中的捕获变量 1315.5.1 定义闭包和不同类型的变量 1315.5.2 捕获变量的行为 1325.5.3 捕获变量到底有什么用处 1335.5.4 捕获变量的延长生存期 1345.5.5 局部变量实例化 1355.5.6 共享和非共享的变量混合使用 1375.5.7 捕获变量的使用规则和小结 1395.6 小结 140第6章 实现迭代器的捷径 1416.1 C# 1:手写迭代器的痛苦 1426.2 C# 2:利用yield语句简化迭代器 1446.2.1 迭代器块和yield return简介 1456.2.2 观察迭代器的工作流程 1466.2.3 进一步了解迭代器执行流程 1486.2.4 具体实现中的奇特之处 1516.3 真实的迭代器示例 1526.3.1 迭代时刻表中的日期 1526.3.2 迭代文件中的行 1536.3.3 使用迭代器块和谓词对项进行延迟过滤 1566.4 使用CCR实现伪同步代码 1576.5 小结 160第7章 结束C# 2的讲解:最后的一些特性 1617.1 分部类型 1627.1.1 在多个文件中创建一个类型 1627.1.2 分部类型的使用 1647.1.3 C# 3独有的分部方法 1667.2 静态类型 1677.3 独立的取值方法/赋值方法属性访问器 1697.4 命名空间别名 1707.4.1 限定的命名空间别名 1717.4.2 全局命名空间别名 1727.4.3 外部别名 1737.5 pragma指令 1747.5.1 警告pragma 1747.5.2 校验和pragma 1757.6 非安全代码中固定大小的缓冲区 1767.7 把内部成员暴露给选定的程序集 1787.7.1 简单情况下的友元程序集 1787.7.2 为什么使用Internals-VisibleTo 1797.7.3 InternalsVisibleTo和签名程序集 1797.8 小结 180第三部分 C# 3:革新写代码的方式第8章 用智能的编译器来防错 1828.1 自动实现的属性 1838.2 隐式类型的局部变量 1858.2.1 用var声明局部变量 1858.2.2 隐式类型的限制 1878.2.3 隐式类型的优缺点 1888.2.4 建议 1898.3 简化的初始化 1908.3.1 定义示例类型 1908.3.2 设置简单属性 1918.3.3 为嵌入对象设置属性 1928.3.4 集合初始化程序 1938.3.5 初始化特性的应用 1968.4 隐式类型的数组 1978.5 匿名类型 1988.5.1 第一次邂逅匿名类型 1988.5.2 匿名类型的成员 2008.5.3 投影初始化程序 2018.5.4 重点何在 2028.6 小结 203第9章 Lambda表达式和表达式树 2049.1 作为委托的Lambda表达式 2059.1.1 准备工作:Func<...>委托类型简介 2059.1.2 第一次转换成Lambda表达式 2069.1.3 用单一表达式作为主体 2079.1.4 隐式类型的参数列表 2079.1.5 单一参数的快捷语法 2089.2 使用List和事件的简单例子 2099.2.1 列表的过滤、排序和操作 2109.2.2 在事件处理程序中进行记录 2119.3 表达式树 2129.3.1 以编程方式构建表达式树 2139.3.2 将表达式树编译成委托 2149.3.3 将C# Lambda表达式转换成表达式树 2159.3.4 位于LINQ核心的表达式树 2189.3.5 LINQ之外的表达式树 2209.4 类型推断和重载决策的改变 2219.4.1 改变的起因:精简泛型方法调用 2219.4.2 推断匿名函数的返回类型 2229.4.3 分两个阶段进行的类型推断 2239.4.4 选择正确的被重载的方法 2279.4.5 类型推断和重载决策 2299.5 小结 229第10章 扩展方法 23010.1 未引入扩展方法之前的状态 23110.2 扩展方法的语法 23310.2.1 声明扩展方法 23310.2.2 调用扩展方法 23410.2.3 扩展方法是怎样被发现的 23510.2.4 在空引用上调用方法 23610.3 .NET 3.5中的扩展方法 23810.3.1 从Enumerable开始起步 23810.3.2 用Where过滤并将方法调用链接到一起 24010.3.3 插曲:似曾相识的Where方法 24110.3.4 用Select方法和匿名类型进行投影 24210.3.5 用OrderBy方法进行排序 24310.3.6 涉及链接的实际例子 24410.4 使用思路和原则 24510.4.1 “扩展世界”和使接口更丰富 24610.4.2 流畅接口 24610.4.3 理智使用扩展方法 24810.5 小结 249第11章 查询表达式和LINQ to Objects 25011.1 LINQ介绍 25111.1.1 LINQ中的基础概念 25111.1.2 定义示例数据模型 25511.2 简单的开始:选择元素 25611.2.1 以数据源作为开始,以选择作为结束 25711.2.2 编译器转译是查询表达式基础的转译 25711.2.3 范围变量和重要的投影 26011.2.4 Cast、OfType和显式类型的范围变量 26211.3 对序列进行过滤和排序 26411.3.1 使用where子句进行过滤 26411.3.2 退化的查询表达式 26511.3.3 使用orderby子句进行排序 26511.4 let子句和透明标识符 26711.4.1 用let来进行中间计算 26711.4.2 透明标识符 26811.5 连接 27011.5.1 使用join子句的内连接 27011.5.2 使用join...into子句进行分组连接 27411.5.3 使用多个from子句进行交叉连接和合并序列 27611.6 分组和延续 27911.6.1 使用group...by子句进行分组 27911.6.2 查询延续 28211.7 在查询表达式和点标记之间作出选择 28511.7.1 需要使用点标记的操作 28511.7.2 使用点标记可能会更简单的查询表达式 28611.7.3 选择查询表达式 28611.8 小结 287第12章 超越集合的LINQ 28912.1 使用LINQ to SQL查询数据库 29012.1.1 数据库和模型 29012.1.2 用查询表达式访问数据库 29212.1.3 包含连接的查询 29412.2 用IQueryable和IQueryProvider进行转换 29612.2.1 IQueryable和相关接口的介绍 29712.2.2 模拟接口实现来记录调用 29812.2.3 把表达式粘合在一起:Queryable的扩展方法 30012.2.4 模拟实际运行的查询提供器 30212.2.5 包装IQueryable 30312.3 LINQ友好的API和LINQ to XML 30312.3.1 LINQ to XML中的核心类型 30412.3.2 声明式构造 30512.3.3 查询单个节点 30812.3.4 合并查询操作符 30912.3.5 与LINQ和谐共处 31012.4 用并行LINQ代替LINQ to Objects 31112.4.1 在单线程中绘制曼德博罗特集 31112.4.2 ParallelEnumerable、ParallelQuery和AsParallel 31312.4.3 调整并行查询 31512.5 使用LINQ to Rx反转查询模型 31612.5.1 IObservable和IObserver 31612.5.2 简单的开始 31812.5.3 查询可观察对象 31912.5.4 意义何在 32112.6 扩展LINQ to Objects 32112.6.1 设计和实现指南 32212.6.2 示例扩展:选择随机元素 32312.7 小结 324第四部分 C# 4:良好的交互性第13章 简化代码的微小修改 32813.1 可选参数和命名实参 32813.1.1 可选参数 32913.1.2 命名实参 33413.1.3 两者相结合 33713.2 改善COM互操作性 34113.2.1 在C# 4之前操纵Word是十分恐怖的 34213.2.2 可选参数和命名实参的复仇 34213.2.3 按值传递ref参数 34313.2.4 调用命名索引器 34413.2.5 链接主互操作程序集 34513.3 接口和委托的泛型可变性 34813.3.1 可变性的种类:协变性和逆变性 34813.3.2 在接口中使用可变性 34913.3.3 在委托中使用可变性 35213.3.4 复杂情况 35313.3.5 限制和说明 35413.4 对锁和字段风格的事件的微小改变 35713.4.1 健壮的锁 35713.4.2 字段风格的事件 35813.5 小结 359第14章 静态语言中的动态绑定 36014.1 何谓、何时、为何、如何 36114.1.1 何谓动态类型 36114.1.2 动态类型什么时候有用,为什么 36214.1.3 C# 4如何提供动态类型 36314.2 关于动态的快速指南 36414.3 动态类型示例 36614.3.1 COM和Office 36714.3.2 动态语言 36814.3.3 纯托管代码中的动态类型 37214.4 幕后原理 37714.4.1 DLR简介 37814.4.2 DLR核心概念 37914.4.3 C#编译器如何处理动态 38214.4.4 更加智能的C#编译器 38514.4.5 动态代码的约束 38814.5 实现动态行为 39014.5.1 使用ExpandoObject 39114.5.2 使用DynamicObject 39414.5.3 实现IDynamicMetaObject-Provider 40014.6 小结 404第五部分 C# 5:简化的异步编程第15章 使用async/await进行异步编程 40615.1 异步函数简介 40715.1.1 初识异步类型 40815.1.2 分解第一个示例 40915.2 思考异步编程 41015.2.1 异步执行的基础 41015.2.2 异步方法 41215.3 语法和语义 41315.3.1 声明异步方法 41315.3.2 异步方法的返回类型 41415.3.3 可等待模式 41515.3.4 await表达式的流 41815.3.5 从异步方法返回 42115.3.6 异常 42215.4 异步匿名函数 42915.5 实现细节:编译器转换 43115.5.1 生成的代码 43215.5.2 骨架方法的结构 43415.5.3 状态机的结构 43515.5.4 一个入口搞定一切 43615.5.5 围绕await表达式的控制 43815.5.6 跟踪栈 43915.5.7 更多内容 44015.6 高效地使用async/await 44115.6.1 基于任务的异步模式 44115.6.2 组合异步操作 44415.6.3 对异步代码编写单元测试 44715.6.4 可等待模式的归来 45015.6.5 在WinRT中执行异步操作 45115.7 小结 452第16章 C# 5附加特性和结束语 45316.1 foreach循环中捕获变量的变化 45316.2 调用者信息特性 45416.2.1 基本行为 45416.2.2 日志 45616.2.3 实现INotifyProperty-Changed 45616.2.4 在非.NET 4.5环境下使用调用者信息特性 45716.3 结束语 458附录A LINQ标准查询操作符 460附录B .NET中的泛型集合 471附录C 版本总结 483第15章 使用async/await进行异步编程本章内容异步的基本目标编写异步方法和委托编译器对异步的转换基于任务的异步模式WinRT中的异步多年来,异步编程对开发者来说就是一根芒刺。我们都知道,异步编程可在等待某个任务完成时,避免线程的占用,但要想正确地实现编程,仍然十分伤脑筋。在(相对于其宏伟蓝图来说仍然十分年轻的).NET Framework中,有三种不同的模型来简化异步编程。.NET 1.x中的BeginFoo/EndFoo方法,使用IAsyncResult和AsyncCallback来传播结果。.NET 2.0中基于事件的异步模式,使用BackgroundWorker和WebClient实现。.NET 4引入并由.NET 4.5扩展的任务并行库(TPL)。尽管TPL经过了精心设计,但用它编写健壮可读的异步代码仍然十分困难。虽然支持并行是一个壮举,但对于异步编程的某些方面来说,最好是从语言层面进行修补,而不是纯粹的库。说明 async/await会改变你的世界观 本章概要中的话题可能会显得索然无味。它是一个正确的概要,但却没能准确传达我对该特性的激动之情。我使用async/await已经两年了,但仍然觉得像刚入学的小学生。我坚信async/await之于异步编程,一定会像C# 3诞生时LINQ之于数据处理一般,除了处理异步要复杂得多。为达到最佳效果,请以万分激动的声音大声阅读本章。希望我能以我的热情影响你对该特性的看法。C# 5的这个主要特性基于TPL,因此可以在适用于异步的地方编写同步形式的代码。意大利面式的回调、事件订阅和支离破碎的错误处理都消失不见,取而代之的是能够清晰表达其意图的异步代码,并且是基于开发者熟悉的结构。它包含一个新的语言构造,可以“等待”(await)一个异步的操作。这个“等待”看上去非常像一个普通的阻塞调用,剩余的代码在异步操作完成前不会继续执行,但实际上它并没有阻塞当前执行线程。如果觉得该语句完全自相矛盾,不要担心,完成本章的学习后,一切就会清晰了。.NET Framework从版本4.5起全心投入了异步编程的怀抱,并为大量操作提供了异步版本。它们遵循基于任务的新异步模式,横跨多个API提供一致的体验。此外,用于在Windows 8中创建Windows Store应用的全新Windows Runtime平台1,还强制所有长时间运行(或有可能长时间运行)的操作都必须使用异步。总而言之,未来是异步的,在处理额外复杂性的时候不使用这个新的语言特性是愚蠢的。即便你使用的不是.NET 4.5,微软还创建了一个NuGet包(Microsoft.Bcl.Async),可以在面向.NET4、Silverlight 4/5、Windows Phone 7.5/8时使用该新特性。

赞(0)
未经允许不得转载:小苏子图书 » 深入理解C#(第3版) 内容简介