《ERLANG趣学指南》PDF下载

  • 购买积分:15 如何计算积分?
  • 作  者:(加)FRED HEBERT著;邓辉,孙鸣译
  • 出 版 社:北京:人民邮电出版社
  • 出版年份:2016
  • ISBN:7115431905
  • 页数:469 页
图书介绍:

第1章 启程 1

1.1 使用Erlang shell 1

1.1.1 输入shell命令 1

1.1.2 退出shell 2

1.2 Erlang基础知识 3

1.2.1 数值类型 3

1.2.2 不变的变量 4

1.2.3 原子 5

1.2.4 布尔代数和比较操作符 6

1.2.5 元组 8

1.2.6 列表 10

1.2.7 列表推导式 13

1.3 处理二进制数据 14

1.3.1 位语法 15

1.3.2 二进制数的按位操作 17

1.3.3 二进制字符串 18

1.3.4 二进制推导式 19

第2章 模块 20

2.1 什么是模块 20

2.2 创建模块 21

2.3 编译代码 23

2.4 定义宏 26

2.5 模块的其他内容 27

2.5.1 元数据 27

2.5.2 环形依赖 28

第3章 函数 29

3.1 模式匹配 29

3.1.1 模式进阶 31

3.1.2 绑定中的变量 31

3.2 卫语句 33

3.3 if表达式 34

3.4 case...of表达式 37

3.5 如何选择 38

第4章 类型 39

4.1 动态强类型 39

4.2 类型转换 40

4.3 数据类型检测函数 41

4.4 致静态类型爱好者 43

第5章 递归 44

5.1 递归的工作原理 44

5.1.1 列表的长度 45

5.1.2 列表长度的尾递归实现 46

5.2 更多递归函数 47

5.2.1 duplicate函数 47

5.2.2 reverse函数 48

5.2.3 sublist函数 49

5.2.4 zip函数 50

5.2.5 快速排序 51

5.3 不仅仅是列表 53

5.4 递归思维 55

第6章 高阶函数 58

6.1 一切都是函数 58

6.2 匿名函数 60

6.2.1 匿名函数的其他用途 60

6.2.2 函数的作用域和闭包 61

6.3 映射、过滤器、折叠以及其他 63

6.3.1 过滤器 63

6.3.2 折叠一切 64

6.3.3 其他抽象 66

第7章 错误和异常 67

7.1 错误编译 67

7.1.1 编译期错误 67

7.1.2 逻辑错误 69

7.1.3 运行时错误 69

7.2 引发异常 71

7.2.1 出错异常 71

7.2.2 退出异常 72

7.2.3 抛出异常 73

7.3 处理异常 74

7.3.1 处理不同类型的异常 74

7.3.2 catch后的after语句 76

7.3.3 尝试多个表达式 76

7.3.4 更多选择 78

7.4 在树中使用try语句 80

第8章 用函数式思维解决问题 82

8.1 逆波兰式计算器 82

8.1 1RPN计算器的工作原理 82

8.1.2 实现RPN计算器 84

8.1.3 代码测试 85

8.2 从希思罗到伦敦 87

8.2.1 递归地解决问题 87

8.2.2 编写代码 89

8.2.3 不使用Erlang shell运行程序 93

第9章 常用数据结构简介 95

9.1 记录 95

9.1.1 定义记录 95

9.1.2 读取记录字段值 97

9.1.3 更新记录 99

9.1.4 共享记录定义 99

9.2 键/值存储 100

9.2.1 小数据量存储 100

9.2.2 大数据量存储:字典和通用平衡树 101

9.3 集合 102

9.4 有向图 104

9.5 队列 104

9.6 小结 105

第10章 并发编程漫游指南 106

10.1 不必惊慌 106

10.2 并发概念 107

10.2.1 伸缩性 108

10.2.2 容错 108

10.2.3 并发实现 109

10.3 并非完全不能线性伸缩 110

10.4 再见,谢谢你的鱼 111

10.4.1 创建进程 112

10.4.2 发送消息 113

10.4.3 接收消息 114

第11章 深入多重处理 118

11.1 定义进程状态 118

11.2 隐藏消息实现 120

11.3 超时 121

11.4 选择性接收 123

11.4.1 选择性接收的风险 124

11.4.2 邮箱使用的其他风险 126

第12章 错误与进程 127

12.1 链接 127

12.1.1 捕获退出信号 129

12.1.2 老异常,新概念 130

12.2 监控器 133

12.3 命名进程 134

第13章 并发应用设计 139

13.1 理解问题 139

13.2 设计协议 141

13.3 目录结构 143

13.4 事件模块 143

13.4.1 事件和循环 144

13.4.2 增加接口 146

13.5 事件服务器 148

13.5.1 处理消息 149

13.5.2 代码热升级 152

13.5.3 隐藏消息细节 153

13.6 测试 155

13.7 增加监督功能 156

13.8 命名空间 157

第14章 OTP简介 158

14.1 提炼通用进程 158

14.2 基础服务器 159

14.2.1 kitty服务器 159

14.2.2 通用化同步调用 161

14.2.3 通用化服务器循环 162

14.2.4 启动函数 164

14.2.5 通用化kitty服务器 165

14.3 专用与通用 166

14.4 面向未来的回调 167

14.4.1 init函数 167

14.4.2 handle call函数 168

14.4.3 handle cast函数 169

14.4.4 handle info函数 169

14.4.5 terminate函数 169

14.4.6 code change函数 169

14.5 gen server实践 170

第15章 令人愤怒的有限状态机 174

15.1 什么是有限状态机 174

15.2 通用有限状态机 178

15.2.1 init函数 178

15.2.2 StateName函数 178

15.2.3 handle event函数 179

15.2.4 handle syn event函数 179

15.2.5 code change和terminate函数 179

15.3 交易系统规格说明 179

15.3.1 操作定义 180

15.3.2 定义状态图和状态迁移 181

15.4 游戏交易 186

15.4.1 公共接口 186

15.4.2 FSM到FSM的函数 187

15.4.3 gen fsm回调函数 189

15.5 为自己骄傲 196

15.6 适用于真实世界吗 197

第16章 事件处理器 198

16.1 处理它!*泵式散弹枪* 198

16.2 通用事件处理器 199

16.2.1 init和terminate函数 200

16.2.2 handle event函数 200

16.2.3 handle call函数 201

16.2.4 handle info函数 201

16.2.5 code change函数 201

16.3 现在是冰壶比赛时间 201

16.3.1 记分牌 202

16.3.2 比赛事件 203

16.3.3 通知新闻界 206

第17章 谁来监督监督者 211

17.1 监督者中的概念 211

17.2 使用监督者 213

17.2.1 重启策略 213

17.2.2 重启限制 215

17.2.3 子进程规格说明 215

17.3 乐队排练 217

17.3.1 音乐人 217

17.3.2 乐队监督者 220

17.4 动态监督 223

17.4.1 动态使用标准监督者 223

17.4.2 使用simple one for one监督者 224

第18章 构建应用 226

18.1 进程池 226

18.1.1 洋葱理论 227

18.1.2 进程池监督树 228

18.2 实现监督者 230

18.3 进程池服务器 233

18.4 实现工作者 239

18.5 运行进程池 240

18.6 小结 242

第19章 构建OTP应用 243

19.1 我还有辆车是一个游泳池 243

19.2 应用资源文件 244

19.3 把ppool转换成OTP应用 246

19.4 application行为 247

19.5 从混乱到应用 249

19.6 库应用 251

第20章 深入OTP应用 253

20.1 从OTP应用到真实的应用 253

20.1.1 应用文件 254

20.1.2 应用回调模块和监督者 255

20.1.3 分派器 256

20.1.4 计数模块 264

20.2 运行应用 265

20.3 包含应用 267

20.4 复杂的终止 267

第21章 发布 268

21.1 修理漏水的管道 268

21.1.1 终止VM 268

21.1.2 更新应用文件 269

21.1.3 编译应用 270

21.2 使用systools构建发布 270

21.2.1 创建启动文件 271

21.2.2 发布打包 272

21.3 使用Reltool构建发布 273

21.4 Reltool技巧集 279

21.5 基于release文件发布 282

第22章 升级Process Quest 283

22.1 升级面临的问题 283

22.2 Erlang学习的第9级 285

22.3 Process Quest 286

22.3.1 regis-1.0.0应用 287

22.3.2 processquest-1.0.0应用 287

22.3.3 sockserv-1.0.0应用 288

22.3.4 发布 289

22.4 改进Process Quest 291

22.4.1 更改code change函数 291

22.4.2 增加appup文件 293

22.4.3 发布升级 296

22.5 Relup回顾 299

第23章 套接字编程 301

23.1 IO列表 301

23.2 UDP和TCP:伙伴协议 302

23.2.1 UDP套接字 303

23.2.2 TCP套接字 306

23.3 使用Inet进行更多的控制 308

23.4 重新审视sockserv 310

23.5 下一步的工作 319

第24章 EUnit:单元测试框架 320

24.1 什么是EUnit 320

24.2 测试生成器 324

24.3 测试夹具 326

24.3.1 其他测试控制方法 328

24.3.2 测试文档 329

24.4 测试regis 329

24.5 EUnit小结 338

第25章 ETS:免费的内存NoSQL数据库 339

25.1 为什么需要ETS 339

25.2 ETS的概念 340

25.3 ETS的基本操作 342

25.3.1 表的创建和删除 342

25.3.2 数据的插入和查询 343

25.4 匹配操作 345

25.5 选择操作 347

25.6 DETS 351

25.7 少说一点,多做一点 351

25.7.1 接口 352

25.7.2 实现细节 352

第26章 分布式编程 357

26.1 这是我的火枪 358

26.2 分布式计算中的谬误 359

26.2.1 网络是可靠的 360

26.2.2 网络没有延迟 360

26.2.3 带宽是无限的 361

26.2.4 网络是安全的 361

26.2.5 网络拓扑不会变化 362

26.2.6 只有一个管理员 363

26.2.7 传输成本是零 363

26.2.8 网络是同质的 363

26.2.9 谬误小结 364

26.3 死亡还是失去联系 364

26.4 CAP定理 365

26.4.1 一致性 366

26.4.2 可用性 366

26.4.3 分区容忍 366

26.4.4 僵尸幸存者和CAP 367

26.5 搭建Erlang集群 369

26.5.1 节点命名 369

26.5.2 连接节点 370

26.5.3 更多工具 371

26.6 cookie 373

26.7 远程shell 374

26.8 隐藏节点 375

26.9 防火墙问题 376

26.10 高级调用 376

26.10.1 net kernel模块 376

26.10.2 global模块 377

26.10.3 rpc模块 378

26.11 小结 380

第27章 分布式OTP应用 381

27.1 更多OTP内容 381

27.2 接管和故障切换 382

27.3 神奇8号球 383

27.3.1 构建应用 384

27.3.2 变身分布式应用 387

第28章 不寻常的Common Test 391

28.1 什么是Common Test 391

28.2 Common Test的组织结构 392

28.3 创建一个简单的测试套件 393

28.4 带状态的测试 396

28.5 测试组 397

28.5.1 定义测试组 398

28.5.2 测试组属性 399

28.5.3 会议室 400

28.6 再谈测试套件 404

28.7 测试规格说明 404

28.7.1 规格说明文件内容 405

28.7.2 创建规格说明文件 406

28.7 3通过规格说明文件运行测试 407

28.8 大规模测试 407

28.8.1 创建分布式测试规格说明文件 409

28.8.2 运行分布式测试 410

28.9 集成CommonTest和EUint 411

28.10 还有其他内容吗 411

第29章 Mnesia——记忆的艺术 412

29.1 Mnesia是什么 412

29.2 应该存储什么呢 413

29.2.1 需要存储的数据 413

29.2.2 表结构 414

29.3 从记录到表 415

29.4 Mnesia数据模式和表 416

29.5 创建表 418

29.5.1 安装数据库 418

29.5.2 启动应用 421

29.6 数据表存取上下文 422

29.7 读、写以及其他操作 423

29.8 实现第一个请求 424

29.8.1 测试增加服务 424

29.8.2 测试查询 427

29.8.3 账目和新的需求 430

29.9 满足老板 432

29.10 删除操作示例 434

29.11 列表推导式查询 437

29.12 记住Mnesia 438

第30章 类型规格说明与Dialyzer 439

30.1 PLT是最好的三明治 439

30.2 成功类型化 440

30.3 类型推导和错误 442

30.4 类型的种类 445

30.4.1 单例类型 445

30.4.2 联合类型和内置类型 445

30.4.3 定义类型 448

30.4.4 记录类型 449

30.5 为函数增加类型声明 450

30.6 类型定义实践 453

30.7 类型导出 457

30.8 OTP行为类型 459

30.9 多态类型 460

30.9.1 我们买了一个动物园 460

30.9.2 注意事项 462

30.10 Dialyzer,我的好朋友 463

30.11 朋友们,就这么多 463

后记 464

附录Erlang语法 467