“即便我已经使用Erlang多年,在编程的时候仍然需要参考《Erlang编程指南》。不同层次的Erlang程序员都会发现本书是有价值的学习和参考资料。”
——Steve Vinoski,《IEEE Internet Computing》专栏作家
《Erlang编程指南》是对Erlang语言的深入介绍。Erlang是任何必须并发、容错和快速响应的环境的理想编程语言。随着多核处理器及其针对并发的新的可扩展方式的发展,Erlang得到了广泛的使用。通过本书,你将学会如何使用Erlang编写复杂的并发程序,不管你是否有编程背景和经验
本书由国际知名的Erlang社区领导者根据他们的培训材料编写而成。本书的重点集中在解释Erlang的语法和语义,并且介绍了其模式匹配、规范列表、递归、调试、网络和并发性等内容。
《Erlang编程指南》可以帮助你:
• 理解Erlang的强大功能及其包含的特殊功能。
• 学习并发背后的概念以及Erlang处理并发的方式。
• 编写高效的Erlang程序并保持代码整洁和良好的可读性。
• 探究Erlang如何满足分布式系统的要求。
• 轻松添加简单的图形用户界面。
• 学习Erlang的跟踪机制以调试并发和分布式系统。
• 使用内置的Mnesia数据库和其他表存储功能。
《Erlang编程指南》每章末尾都提供了练习题,并且由简单的示例贯穿全书。
序 1
前言 3
第1章 引言 9
为什么我应该使用Erlang 9
Erlang语言的历史及发展 11
Erlang的特性 12
Erlang和多核 17
案例研究 18
应该如何使用Erlang 21
第2章 Erlang基础 22
整数 22
Erlang终端 23
浮点数 23
基元 25
布尔类型 27
元组 28
列表 29
项元比较 34
变量 36
复杂数据结构 38
模式匹配 40
函数 44
模块 46
练习 50
第3章 Erlang顺序编程 52
条件评估 52
保护元 57
内置函数 60
递归 66
运行时错误 75
处理错误 77
模块库 84
调试器 87
练习 90
第4章 并发编程 95
创建进程 96
消息传递 98
接收消息 100
注册进程 107
超时 110
性能基准测试 111
进程架构 112
尾递归和内存泄漏 113
面向并发程序设计的个案研究 115
竞争条件、死锁和饥饿进程 116
进程管理器 118
练习 119
第5章 进程设计模式 121
客户端/服务器模型 122
进程模式实例 128
有限状态机 130
事件管理器和句柄 134
练习 141
第6章 进程错误处理机制 143
进程链接和退出信号 143
健壮性系统 152
练习 158
第7章 记录和宏 161
记录 162
宏 168
练习 172
第8章 软件升级 175
升级模块 175
幕后 178
升级过程 184
.erlang文件 188
练习 188
第9章 更多数据类型和高级别构造 190
实践中的函数式编程 190
Funs和高阶函数 191
列表解析 198
二进制类型和序列化 202
引用 211
练习 212
第10章 ETS和Dets表 214
ETS表 214
Dets表 228
移动用户数据库实例 231
练习 242
第11章 Erlang中的分布式编程 244
Erlang中的分布式系统 244
Erlang中的分布式计算:基础 246
epmd进程 259
练习 260
第12章 OTP行为包 261
OTP行为包介绍 261
通用服务器 264
监控进程 274
应用 278
版本发行的处理 284
其他行为包和更多阅读资源 287
练习 288
第13章 Mnesia介绍 290
何时使用Mnesia 290
配置Mnesia 292
事务处理 296
分区网络 301
扩展阅读 302
练习 303
第14章 图形用户界面编程wxErlang 305
wxWidgets 305
wxErlang:wxWidgets绑定到Erlang 306
第一个实例:MicroBlog 309
MiniBlog实例 313
获取和运行wxErlang 316
练习 317
第15章 套接字编程 319
用户数据报协议 319
传输控制协议 323
inet模块 328
扩展阅读 329
练习 330
第16章 Erlang与其他编程语言接口 332
交互运作概况 332
与Java交互运作 334
C节点 339
Unix终端的Erlang调用:erl_call 343
端口程序 343
通信支持库 347
内联驱动程序和FFI 349
练习 350
第17章 跟踪内置函数,dbg跟踪器以及匹配规则 351
引言 351
跟踪内置函数 352
用trace_pattern内置函数跟踪调用 358
dbg跟踪器 362
匹配规则:fun语法 370
匹配规则:螺母和螺栓 379
扩展阅读 387
练习 388
第18章 类型和文档 390
Erlang中的类型 390
TypEr: 成功类型和类型推断 394
使用EDoc生成文档 397
练习 405
第19章 EUnit和测试驱动开发 406
测试驱动开发 406
EUnit 407
EUnit的基础架构 411
测试基于状态的系统 413
在Erlang中测试并发程序 414
练习 415
第20章 风格和效率 417
应用和模块 417
进程和并发 422
格式约定 425
编码策略 431
效率 433
最后 437
附录 使用Erlang 439
《拜托了,黏土!插画风黏土小物制作》内容简介:手作,充盈了我们的闲适时光。有趣、新鲜的手工小物,给我们的生活增添了多彩的乐
《劫持》内容简介:《劫持》是一本探讨人与科技的关系的书,基于一位心理学博士20年的临床经验及其作为神经认知科学研究者的脑—电
《平面设计配色全攻略》实例讲解部分共分为四个章节,分别为广告招贴、书籍杂志、品牌形象和产品包装四个类别。再将每个类别划分
《配色宝典》是一本集配色理论和配色实例为一体的便携式工具书。配色理论部分以日本视觉设计研究所研发的色立体为基础,将色彩分
《中东问题研究》内容简介:《中东问题研究》为国内唯一一本专门以中东地区为研究对象的学术辑刊,内容涉及中东历史、经济、政治、
《朝花夕拾》内容简介:本书是鲁迅先生家喻户晓的回忆性散文集,比较完整地记录了他从幼年到青年时期的生活经历和思想脉络,在塑造
《无线通信与移动通信中信号处理研究的新进展》总结了近年来通信信号处理领域的最新研究成果,概括地讨论了通信信号处理中最具特
移动通信是当前发展最快、应用最广和最前沿的通信领域之一。本书共分为七章,主要介绍了移动通信的基本概念,移动通信网网络技术
《价值发现》内容简介:市场上关于价值投资的图书多如牛毛,但绝大部分偏于理念阐述而缺乏实战案例,读者即便理解了价值投资理念,
沈括是我国古代历史上一位伟大的科学家。他留下的《梦溪笔谈》一书,成为我国古代科学技术成果的资料库,长期以来,一直受到人们
骇客 内容简介 本书介绍了游戏设计、动画设计的基本知识、要素等,并展示了一些设计作品,供读者参考。骇客 目录 CYBER CONNECT公司主页欢迎来到CYBE...
Inlife,uncertaintysurroundsus.Thingsthatwethoughtweregoodforusturnouttobebadforu...
《经典电影如何讲故事》内容简介:好电影都讲了一个好故事,那些遭遇“滑铁卢”、不受市场待见的“烂片”,很大程度上是故事设计存
《软件困局》内容简介:软件工程其实并没有多少“工程”的成分,这已经是公开的秘密了。自计算机诞生以来,特别是20世纪60年代大批
《党政机关公文标准与格式应用指南》内容简介:本书以新版《党政机关公文格式》国家标准和《党政机关公文处理工作条例》为理论基础
《网络至死:如何在喧嚣的互联网时代重获我们的创造力和思维力》内容简介:我们也许已经晓悟,但也许并未察觉,我们正陷入空前的“
Adetailedexaminationofinteriorroutingprotocols--completelyupdatedinanewedition*A...
《2009-2010智能科学与技术学科发展报告》包含1篇综合报告和11篇专题报告。其中,综合报告的主要内容包括:(1)我国智能科学与技
揭开时间之谜一直是人类一个最古老的梦想。其中可想而知的是,与了解过去一切相比,人们更渴望拉开未来的帷幕。其实,对于往事的
《第N+1个》内容简介:12名受害人,凶手作案手法相同,犯罪现场相似,绵延一年,警方却毫无头绪。一部名为《第N 1个》的小说在风口