图书介绍

深入理解C# 第3版PDF|Epub|txt|kindle电子书版本网盘下载

深入理解C# 第3版
  • (英)斯基特著 著
  • 出版社: 北京:人民邮电出版社
  • ISBN:9787115346421
  • 出版时间:2014
  • 标注页数:490页
  • 文件大小:245MB
  • 文件页数:513页
  • 主题词:C语言-程序设计

PDF下载


点此进入-本书在线PDF格式电子书下载【推荐-云解压-方便快捷】直接下载PDF格式图书。移动端-PC端通用
种子下载[BT下载速度快]温馨提示:(请使用BT下载软件FDM进行下载)软件下载地址页直链下载[便捷但速度慢]  [在线试读本书]   [在线获取解压码]

下载说明

深入理解C# 第3版PDF格式电子书版下载

下载的文件为RAR压缩包。需要使用解压软件进行解压得到PDF格式图书。

建议使用BT下载工具Free Download Manager进行下载,简称FDM(免费,没有广告,支持多平台)。本站资源全部打包为BT种子。所以需要使用专业的BT下载软件进行下载。如BitComet qBittorrent uTorrent等BT下载工具。迅雷目前由于本站不是热门资源。不推荐使用!后期资源热门了。安装了迅雷也可以迅雷进行下载!

(文件页数 要大于 标注页数,上中下等多册电子书除外)

注意:本站所有压缩包均有解压码: 点击下载压缩包解压工具

图书目录

第一部分 基础知识2

第1章 C#开发的进化史2

1.1从简单的数据类型开始3

1.1.1 C# 1中定义的产品类型3

1.1.2 C# 2中的强类型集合4

1.1.3 C# 3中自动实现的属性5

1.1.4 C# 4中的命名实参6

1.2排序和过滤7

1.2.1按名称对产品进行排序7

1.2.2查询集合10

1.3处理未知数据12

1.3.1表示未知的价格12

1.3.2可选参数和默认值13

1.4 LINQ简介14

1.4.1查询表达式和进程内查询14

1.4.2查询XML15

1.4.3 LINQ to SQL16

1.5 COM和动态类型17

1.5.1简化COM互操作17

1.5.2与动态语言互操作18

1.6轻松编写异步代码19

1.7剖析.NET平台20

1.7.1 C#语言20

1.7.2运行时21

1.7.3框架库21

1.8怎样写出超炫的代码22

1.8.1采用代码段形式的全能代码22

1.8.2教学代码不是产品代码23

1.8.3你的新朋友:语言规范23

1.9小结24

第2章 C#1所搭建的核心基础25

2.1委托25

2.1.1简单委托的构成26

2.1.2合并和删除委托30

2.1.3对事件的简单讨论32

2.1.4委托总结33

2.2类型系统的特征33

2.2.1 C#在类型系统世界中的位置34

2.2.2 C# 1的类型系统何时不够用36

2.2.3类型系统特征总结39

2.3值类型和引用类型39

2.3.1现实世界中的值和引用39

2.3.2值类型和引用类型基础知识40

2.3.3走出误区41

2.3.4装箱和拆箱43

2.3.5值类型和引用类型小结44

2.4 C# 1之外:构建于坚实基础之上的新特性44

2.4.1与委托有关的特性44

2.4.2与类型系统有关的特性46

2.4.3与值类型有关的特性48

2.5小结49

第二部分C# 2:解决C#1的问题52

第3章 用泛型实现参数化类型52

3.1为什么需要泛型53

3.2日常使用的简单泛型54

3.2.1通过例子来学习:泛型字典54

3.2.2泛型类型和类型参数56

3.2.3泛型方法和判读泛型声明59

3.3深化与提高62

3.3.1类型约束62

3.3.2泛型方法类型实参的类型推断67

3.3.3实现泛型68

3.4高级泛型73

3.4.1静态字段和静态构造函数73

3.4.2 JIT编译器如何处理泛型75

3.4.3泛型迭代77

3.4.4反射和泛型79

3.5泛型在C#和其他语言中的限制82

3.5.1泛型可变性的缺乏83

3.5.2缺乏操作符约束或者“数值”约束87

3.5.3缺乏泛型属性、索引器和其他成员类型88

3.5.4同C++模板的对比89

3.5.5和Java泛型的对比90

3.6小结91

第4章 可空类型93

4.1没有值时怎么办93

4.1.1为什么值类型的变量不能是null94

4.1.2在C# 1中表示空值的模式94

4.2 System.Nullable〈T〉和System.Nullable96

4.2.1 Nullable〈T〉简介96

4.2.2 Nullable〈T〉装箱和拆箱99

4.2.3 Nullable〈T〉实例的相等性100

4.2.4来自非泛型Nullable类的支持101

4.3 C# 2为可空类型提供的语法糖101

4.3.1?修饰符102

4.3.2使用null进行赋值和比较103

4.3.3可空转换和操作符105

4.3.4可空逻辑108

4.3.5对可空类型使用as操作符109

4.3.6空合并操作符110

4.4可空类型的新奇用法112

4.4.1尝试一个不使用输出参数的操作113

4.4.2空合并操作符让比较不再痛苦115

4.5小结117

第5章 进入快速通道的委托118

5.1向笨拙的委托语法说拜拜119

5.2方法组转换120

5.3协变性和逆变性122

5.3.1委托参数的逆变性122

5.3.2委托返回类型的协变性123

5.3.3不兼容的风险124

5.4使用匿名方法的内联委托操作125

5.4.1从简单的开始:处理一个参数126

5.4.2匿名方法的返回值128

5.4.3忽略委托参数129

5.5匿名方法中的捕获变量131

5.5.1定义闭包和不同类型的变量131

5.5.2捕获变量的行为132

5.5.3捕获变量到底有什么用处133

5.5.4捕获变量的延长生存期134

5.5.5局部变量实例化135

5.5.6共享和非共享的变量混合使用137

5.5.7捕获变量的使用规则和小结139

5.6小结140

第6章 实现迭代器的捷径141

6.1 C# 1:手写迭代器的痛苦142

6.2 C# 2:利用yield语句简化迭代器144

6.2.1迭代器块和yield return简介145

6.2.2观察迭代器的工作流程146

6.2.3进一步了解迭代器执行流程148

6.2.4具体实现中的奇特之处151

6.3真实的迭代器示例152

6.3.1迭代时刻表中的日期152

6.3.2迭代文件中的行153

6.3.3使用迭代器块和谓词对项进行延迟过滤156

6.4使用CCR实现伪同步代码157

6.5小结160

第7章 结束C# 2的讲解:最后的一些特性161

7.1分部类型162

7.1.1在多个文件中创建一个类型162

7.1.2分部类型的使用164

7.1.3 C# 3独有的分部方法166

7.2静态类型167

7.3独立的取值方法/赋值方法属性访问器169

7.4命名空间别名170

7.4.1限定的命名空间别名171

7.4.2全局命名空间别名172

7.4.3外部别名173

7.5 pragma指令174

7.5.1警告pragma174

7.5.2校验和pragma175

7.6非安全代码中固定大小的缓冲区176

7.7把内部成员暴露给选定的程序集178

7.7.1简单情况下的友元程序集178

7.7.2为什么使用Internals-VisibleTo179

7.7.3InternalsVisibleTo和签名程序集179

7.8小结180

第三部分 C# 3:革新写代码的方式182

第8章 用智能的编译器来防错182

8.1自动实现的属性183

8.2隐式类型的局部变量185

8.2.1用var声明局部变量185

8.2.2隐式类型的限制187

8.2.3隐式类型的优缺点188

8.2.4建议189

8.3简化的初始化190

8.3.1定义示例类型190

8.3.2设置简单属性191

8.3.3为嵌入对象设置属性192

8.3.4集合初始化程序193

8.3.5初始化特性的应用196

8.4隐式类型的数组197

8.5匿名类型198

8.5.1第一次邂逅匿名类型198

8.5.2匿名类型的成员200

8.5.3投影初始化程序201

8.5.4重点何在202

8.6小结203

第9章 Lambda表达式和表达式树204

9.1作为委托的Lambda表达式205

9.1.1准备工作:Func〈...〉委托类型简介205

9.1.2第一次转换成Lambda表达式206

9.1.3用单一表达式作为主体207

9.1.4隐式类型的参数列表207

9.1.5单一参数的快捷语法208

9.2使用List〈T〉和事件的简单例子209

9.2.1列表的过滤、排序和操作210

9.2.2在事件处理程序中进行记录211

9.3表达式树212

9.3.1以编程方式构建表达式树213

9.3.2将表达式树编译成委托214

9.3.3将C# Lambda表达式转换成表达式树215

9.3.4位于LINQ核心的表达式树218

9.3.5 LINQ之外的表达式树220

9.4类型推断和重载决策的改变221

9.4.1改变的起因:精简泛型方法调用221

9.4.2推断匿名函数的返回类型222

9.4.3分两个阶段进行的类型推断223

9.4.4选择正确的被重载的方法227

9.4.5类型推断和重载决策229

9.5小结229

第10章 扩展方法230

10.1未引入扩展方法之前的状态231

10.2扩展方法的语法233

10.2.1声明扩展方法233

10.2.2调用扩展方法234

10.2.3扩展方法是怎样被发现的235

10.2.4在空引用上调用方法236

10.3 .NET 3.5中的扩展方法238

10.3.1从Enumerable开始起步238

10.3.2用Where过滤并将方法调用链接到一起240

10.3.3插曲:似曾相识的Where方法241

10.3.4用Select方法和匿名类型进行投影242

10.3.5用OrderBy方法进行排序243

10.3.6涉及链接的实际例子244

10.4使用思路和原则245

10.4.1“扩展世界”和使接口更丰富246

10.4.2流畅接口246

10.4.3理智使用扩展方法248

10.5小结249

第11章 查询表达式和LINQ to Objects250

11.1 LINQ介绍251

11.1.1 LINQ中的基础概念251

11.1.2定义示例数据模型255

11.2简单的开始:选择元素256

11.2.1以数据源作为开始,以选择作为结束257

11.2.2编译器转译是查询表达式基础的转译257

11.2.3范围变量和重要的投影260

11.2.4 Cast、 OfType和显式类型的范围变量262

11.3对序列进行过滤和排序264

11.3.1使用where子句进行过滤264

11.3.2退化的查询表达式265

11.3.3使用orderby子句进行排序265

11.4 let子句和透明标识符267

11.4.1用let来进行中间计算267

11.4.2透明标识符268

11.5连接270

11.5.1使用join子句的内连接270

11.5.2使用join .into子句进行分组连接274

11.5.3使用多个from子句进行交叉连接和合并序列276

11.6分组和延续279

11.6.1使用group .by子句进行分组279

11.6.2查询延续282

11.7在查询表达式和点标记之间作出选择285

11.7.1需要使用点标记的操作285

11.7.2使用点标记可能会更简单的查询表达式286

11.7.3选择查询表达式286

11.8小结287

第12章 超越集合的LINQ289

12.1使用LINQ to SQL查询数据库290

12.1.1数据库和模型290

12.1.2用查询表达式访问数据库292

12.1.3包含连接的查询294

12.2用IQueryable和IQueryProvider进行转换296

12.2.1IQueryable〈T〉和相关接口的介绍297

12.2.2模拟接口实现来记录调用298

12.2.3把表达式粘合在一起:Queryable的扩展方法300

12.2.4模拟实际运行的查询提供器302

12.2.5包装IQueryable303

12.3 LINQ友好的API和LINQ to XML303

12.3.1 LINQ to XML中的核心类型304

12.3.2声明式构造305

12.3.3查询单个节点308

12.3.4合并查询操作符309

12.3.5与LINQ和谐共处310

12.4用并行LINQ代替LINQ to Objects311

12.4.1在单线程中绘制曼德博罗特集311

12.4.2 ParallelEnumerable、ParallelQuery和AsParallel313

12.4.3调整并行查询315

12.5使用LINQ to Rx反转查询模型316

12.5.1Iobservable〈T〉和Iobserver〈T〉316

12.5.2简单的开始318

12.5.3查询可观察对象319

12.5.4意义何在321

12.6扩展LINQ to Objects321

12.6.1设计和实现指南322

12.6.2示例扩展:选择随机元素323

12.7小结324

第四部分 C# 4:良好的交互性328

第13章 简化代码的微小修改328

13.1可选参数和命名实参328

13.1.1可选参数329

13.1.2命名实参334

13.1.3两者相结合337

13.2改善COM互操作性341

13.2.1在C# 4之前操纵Word是十分恐怖的342

13.2.2可选参数和命名实参的复仇342

13.2.3按值传递ref参数343

13.2.4调用命名索引器344

13.2.5链接主互操作程序集345

13.3接口和委托的泛型可变性348

13.3.1可变性的种类:协变性和逆变性348

13.3.2在接口中使用可变性349

13.3.3在委托中使用可变性352

13.3.4复杂情况353

13.3.5限制和说明354

13.4对锁和字段风格的事件的微小改变357

13.4.1健壮的锁357

13.4.2字段风格的事件358

13.5小结359

第14章 静态语言中的动态绑定360

14.1何谓、何时、为何、如何361

14.1.1何谓动态类型361

14.1.2动态类型什么时候有用,为什么362

14.1.3 C# 4如何提供动态类型363

14.2关于动态的快速指南364

14.3动态类型示例366

14.3.1 COM和Office367

14.3.2动态语言368

14.3.3纯托管代码中的动态类型372

14.4幕后原理377

14.4.1 DLR简介378

14.4.2 DLR核心概念379

14.4.3 C#编译器如何处理动态382

14.4.4更加智能的C#编译器385

14.4.5动态代码的约束388

14.5实现动态行为390

14.5.1使用Expandoobj ect391

14.5.2使用Dynamicobj ect394

14.5.3实现IDynamicMetaobject-Provider400

14.6小结404

第五部分C# 5:简化的异步编程406

第15章 使用async/await进行异步编程406

15.1异步函数简介407

15.1.1初识异步类型408

15.1.2分解第一个示例409

15.2思考异步编程410

15.2.1异步执行的基础410

15.2.2异步方法412

15.3语法和语义413

15.3.1声明异步方法413

15.3.2异步方法的返回类型414

15.3.3可等待模式415

15.3.4 await表达式的流418

15.3.5从异步方法返回421

15.3.6异常422

15.4异步匿名函数429

15.5实现细节:编译器转换431

15.5.1生成的代码432

15.5.2骨架方法的结构434

15.5.3状态机的结构435

15.5.4一个入口搞定一切436

15.5.5围绕await表达式的控制438

15.5.6跟踪栈439

15.5.7更多内容440

15.6高效地使用async/await441

15.6.1基于任务的异步模式441

15.6.2组合异步操作444

15.6.3对异步代码编写单元测试447

15.6.4可等待模式的归来450

15.6.5在WinRT中执行异步操作451

15.7小结452

第16章 C# 5附加特性和结束语453

16.1 foreach循环中捕获变量的变化453

16.2调用者信息特性454

16.2.1基本行为454

16.2.2日志456

16.2.3实现INotifyProperty-Changed456

16.2.4在非.NET 4.5环境下使用调用者信息特性457

16.3结束语458

附录A LINQ标准查询操作符460

附录B .NET中的泛型集合471

附录C版本总结483

热门推荐