图书介绍

C#多线程编程实战pdf电子书版本下载

C#多线程编程实战
  • (美)EugeneAgafonov著 著
  • 出版社: 北京:机械工业出版社
  • ISBN:9787111493488
  • 出版时间:2015
  • 标注页数:197页
  • 文件大小:23MB
  • 文件页数:217页
  • 主题词:C语言-程序设计

PDF下载


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

下载说明

C#多线程编程实战PDF格式电子书版下载

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

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

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

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

图书目录

第1章 线程基础 1

1.1 简介 1

1.2 使用C#创建线程 2

1.2.1 准备工作 2

1.2.2 实现方式 2

1.2.3 工作原理 4

1.3 暂停线程 4

1.3.1 准备工作 5

1.3.2 实现方式 5

1.3.3 工作原理 5

1.4 线程等待 6

1.4.1 准备工作 6

1.4.2 实现方式 6

1.4.3 工作原理 7

1.5 终止线程 7

1.5.1 准备工作 7

1.5.2 实现方式 7

1.5.3 工作原理 8

1.6 检测线程状态 8

1.6.1 准备工作 8

1.6.2 实现方式 8

1.6.3 工作原理 9

1.7 线程优先级 10

1.7.1 准备工作 10

1.7.2 实现方式 10

1.7.3 工作原理 11

1.8 前台线程和后台线程 12

1.8.1 准备工作 12

1.8.2 实现方式 12

1.8.3 工作原理 13

1.9 向线程传递参数 13

1.9.1 准备工作 13

1.9.2 实现方式 13

1.9.3 工作原理 15

1.9.4 更多信息 15

1.10 使用C#中的lock关键字 16

1.10.1 准备工作 16

1.10.2 实现方式 16

1.10.3 工作原理 18

1.11 使用Monitor类锁定资源 18

1.11.1 准备工作 18

1.11.2 实现方式 18

1.11.3 工作原理 20

1.12 处理异常 20

1.12.1 准备工作 20

1.12.2 实现方式 21

1.12.3 工作原理 22

第2章 线程同步 23

2.1 简介 23

2.2 执行基本的原子操作 24

2.2.1 准备工作 24

2.2.2 实现方式 24

2.2.3 工作原理 26

2.3 使用Mutex类 27

2.3.1 准备工作 27

2.3.2 实现方式 27

2.3.3 工作原理 27

2.4 使用SemaphoreSlim类 28

2.4.1 准备工作 28

2.4.2 实现方式 28

2.4.3 工作原理 29

2.4.4 更多信息 29

2.5 使用AutoResetEvent类 29

2.5.1 准备工作 30

2.5.2 实现方式 30

2.5.3 工作原理 31

2.6 使用ManualResetEventSlim类 31

2.6.1 准备工作 31

2.6.2 实现方式 31

2.6.3 工作原理 32

2.6.4 更多信息 33

2.7 使用CountDownEvent类 33

2.7.1 准备工作 33

2.7.2 实现方式 33

2.7.3 工作原理 34

2.8 使用Barrier类 34

2.8.1 准备工作 34

2.8.2 实现方式 34

2.8.3 工作原理 35

2.9 使用ReaderWriterLockSlim类 35

2.9.1 准备工作 36

2.9.2 实现方式 36

2.9.3 工作原理 37

2.10 使用SpinWait类 38

2.10.1 准备工作 38

2.10.2 实现方式 38

2.10.3 工作原理 39

第3章 使用线程池 40

3.1 简介 40

3.2 在线程池中调用委托 41

3.2.1 准备工作 42

3.2.2 实现方式 42

3.2.3 工作原理 43

3.3 向线程池中放入异步操作 44

3.3.1 准备工作 44

3.3.2 实现方式 44

3.3.3 工作原理 45

3.4 线程池与并行度 45

3.4.1 准备工作 46

3.4.2 实现方式 46

3.4.3 工作原理 47

3.5 实现一个取消选项 47

3.5.1 准备工作 47

3.5.2 实现方式 48

3.5.3 工作原理 49

3.6 在线程池中使用等待事件处理器及超时 50

3.6.1 准备工作 50

3.6.2 实现方式 50

3.6.3 工作原理 51

3.6.4 更多信息 51

3.7 使用计时器 52

3.7.1 准备工作 52

3.7.2 实现方式 52

3.7.3 工作原理 53

3.8 使用BackgroundWorker组件 53

3.8.1 准备工作 53

3.8.2 实现方式 53

3.8.3 工作原理 55

第4章 使用任务并行库 56

4.1 简介 56

4.2 创建任务 57

4.2.1 准备工作 58

4.2.2 实现方式 58

4.2.3 工作原理 59

4.3 使用任务执行基本的操作 59

4.3.1 准备工作 60

4.3.2 实现方式 60

4.3.3 工作原理 61

4.4 组合任务 61

4.4.1 准备工作 61

4.4.2 实现方式 61

4.4.3 工作原理 63

4.5 将APM模式转换为任务 63

4.5.1 准备工作 64

4.5.2 实现方式 64

4.5.3 工作原理 66

4.6 将EAP模式转换为任务 66

4.6.1 准备工作 66

4.6.2 实现方式 67

4.6.3 工作原理 68

4.7 实现取消选项 68

4.7.1 准备工作 68

4.7.2 实现方式 68

4.7.3 工作原理 69

4.8 处理任务中的异常 69

4.8.1 准备工作 70

4.8.2 实现方式 70

4.8.3 工作原理 71

4.8.4 更多信息 71

4.9 并行运行任务 72

4.9.1 准备工作 72

4.9.2 实现方式 72

4.9.3 工作原理 73

4.10 使用TaskScheduler配置任务的执行 73

4.10.1 准备工作 73

4.10.2 实现方式 74

4.10.3 工作原理 76

第5章 使用C# 5.0 78

5.1 简介 78

5.2 使用await操作符获取异步任务结果 80

5.2.1 准备工作 80

5.2.2 实现方式 80

5.2.3 工作原理 81

5.3 在lambda表达式中使用await操作符 82

5.3.1 准备工作 82

5.3.2 实现方式 82

5.3.3 工作原理 83

5.4 对连续的异步任务使用await操作符 83

5.4.1 准备工作 84

5.4.2 实现方式 84

5.4.3 工作原理 85

5.5 对并行执行的异步任务使用await操作符 86

5.5.1 准备工作 86

5.5.2 实现方式 86

5.5.3 工作原理 87

5.6 处理异步操作中的异常 88

5.6.1 准备工作 88

5.6.2 实现方式 88

5.6.3 工作原理 89

5.7 避免使用捕获的同步上下文 90

5.7.1 准备工作 90

5.7.2 实现方式 90

5.7.3 工作原理 92

5.8 使用async void方法 93

5.8.1 准备工作 93

5.8.2 实现方式 93

5.8.3 工作原理 95

5.9 设计一个自定义的awaitable类型 96

5.9.1 准备工作 96

5.9.2 实现方式 96

5.9.3 工作原理 97

5.10 对动态类型使用await 98

5.10.1 准备工作 99

5.10.2 实现方式 99

5.10.3 工作原理 101

第6章 使用并发集合 102

6.1 简介 102

6.2 使用ConcurrentDictionary 103

6.2.1 准备工作 104

6.2.2 实现方式 104

6.2.3 工作原理 105

6.3 使用ConcurrentQueue实现异步处理 105

6.3.1 准备工作 106

6.3.2 实现方式 106

6.3.3 工作原理 107

6.4 改变ConcurrentStack异步处理顺序 108

6.4.1 准备工作 108

6.4.2 实现方式 108

6.4.3 工作原理 109

6.5 使用ConcurrentBag创建一个可扩展的爬虫 110

6.5.1 准备工作 110

6.5.2 实现方式 110

6.5.3 工作原理 113

6.6 使用BlockingCollection进行异步处理 113

6.6.1 准备工作 113

6.6.2 实现方式 113

6.6.3 工作原理 115

第7章 使用PLINQ 116

7.1 简介 116

7.2 使用Parallel类 117

7.2.1 准备工作 118

7.2.2 实现方式 118

7.2.3 工作原理 119

7.3 并行化LINQ查询 119

7.3.1 准备工作 119

7.3.2 实现方式 120

7.3.3 工作原理 122

7.4 调整PLINQ查询的参数 122

7.4.1 准备工作 122

7.4.2 实现方式 123

7.4.3 工作原理 124

7.5 处理PLINQ查询中的异常 125

7.5.1 准备工作 125

7.5.2 实现方式 125

7.5.3 工作原理 126

7.6 管理PLINQ查询中的数据分区 126

7.6.1 准备工作 127

7.6.2 实现方式 127

7.6.3 工作原理 128

7.7 为PLINQ查询创建一个自定义的聚合器 129

7.7.1 准备工作 129

7.7.2 实现方式 129

7.7.3 工作原理 131

第8章 使用Reactive Extensions 132

8.1 简介 132

8.2 将普通集合转换为异步的可观察集合 133

8.2.1 准备工作 133

8.2.2 实现方式 133

8.2.3 工作原理 135

8.3 编写自定义的可观察对象 136

8.3.1 准备工作 136

8.3.2 实现方式 136

8.3.3 工作原理 138

8.4 使用Subject 138

8.4.1 准备工作 138

8.4.2 实现方式 138

8.4.3 工作原理 140

8.5 创建可观察的对象 141

8.5.1 准备工作 141

8.5.2 实现方式 141

8.5.3 工作原理 143

8.6 对可观察的集合使用LINQ查询 144

8.6.1 准备工作 144

8.6.2 实现方式 144

8.6.3 工作原理 145

8.7 使用Rx创建异步操作 146

8.7.1 准备工作 146

8.7.2 实现方式 146

8.7.3 工作原理 148

第9章 使用异步I/O 150

9.1 简介 150

9.2 异步地使用文件 152

9.2.1 准备工作 152

9.2.2 实现方式 152

9.2.3 工作原理 154

9.3 编写一个异步的HTTP服务器和客户端 155

9.3.1 准备工作 155

9.3.2 实现方式 155

9.3.3 工作原理 157

9.4 异步操作数据库 157

9.4.1 准备工作 157

9.4.2 实现方式 158

9.4.3 工作原理 160

9.5 异步调用WCF服务 161

9.5.1 准备工作 161

9.5.2 实现方式 161

9.5.3 工作原理 164

第10章 并行编程模式 165

10.1 简介 165

10.2 实现惰性求值的共享状态 166

10.2.1 准备工作 166

10.2.2 实现方式 166

10.2.3 工作原理 169

10.3 使用BlockingCollection实现并行管道 170

10.3.1 准备工作 170

10.3.2 实现方式 170

10.3.3 工作原理 174

10.4 使用TPL数据流实现并行管道 175

10.4.1 准备工作 175

10.4.2 实现方式 175

10.4.3 工作原理 177

10.5 使用PLINQ实现Map/Reduce模式 178

10.5.1 准备工作 178

10.5.2 实现方式 178

10.5.3 工作原理 181

第11章 更多信息 183

11.1 简介 183

11.2 在Windows商店应用中使用计时器 184

11.2.1 准备工作 184

11.2.2 实现方式 184

11.2.3 工作原理 188

11.3 在通常的应用程序中使用WinRT 189

11.3.1 准备工作 189

11.3.2 实现方式 189

11.3.3 工作原理 191

11.4 在Windows商店应用中使用BackgroundTask 192

11.4.1 准备工作 192

11.4.2 实现方式 192

11.4.3 工作原理 197

精品推荐