出版社: 人民邮电出版社
副标题: Java虚拟机多核编程实战
原作名: Programming Scala: Tackle Multi-Core Complexity on the Java Virtual Machine
译者: 郑晔 / 李剑
出版年: 2010-8
页数: 180
定价: 39.00
丛书: 图灵程序设计丛书·Java系列
ISBN: 9787115232953
内容简介 · · · · · ·
Scala是一种针对 JVM 的通用的编程语言,用来以简明、优雅、类型安全的方式表示常见的编程模式。它无缝集成了面向对象语言和函数式语言的特性,可以大大提高JAVA程序员的编程效率。Twitter、SAP等知名企业已经开始在一些应用里使用Scala,很多新的程序员也开始学习它。
本书循序渐进地介绍了Scala的函数式编程基础,虽然篇幅短小,却切中要害。读者可以学会使用Scala静态语言的强大功能创建简洁、可扩展、高度可并行的代码。对于多核时代JVM上的并发编程,Scala是绝好的工具,而本书是你必不可少的向导。
Scala程序设计的创作者
· · · · · ·
作者简介 · · · · · ·
Venkat Subramaniam,Agile Developer创办人,培训并指导了美国、加拿大、印度和欧洲多国的上千名软件开发人员,并多次应邀在各种大会上发表演讲。他是《高效程序员的45个习惯:敏捷开发修炼之道》(2007年Jolt大奖作品)的第一作者,还著有.NET Gotchas(O’Reilly)、Programming Groovy(Pragmatic)等书。
目录 · · · · · ·
1.1 为何选择Scala 1
1.2 何为Scala 3
1.3 函数式编程 7
1.4 本书的内容 9
1.5 本书面向的读者 11
1.6 致谢 11
第2章 起步 13
2.1 下载Scala 13
2.2 安装Scala 13
2.2.1 在Windows上安装Scala 14
2.2.2 在类UNIX系统上安装Scala 14
2.3 让Scala跑起来 15
2.4 命令行上的Scala 16
2.5 把Scala代码当作脚本运行 17
2.5.1 在类UNIX系统上作为脚本运行 17
2.5.2 在Windows上作为脚本运行 18
2.6 在IDE里面运行Scala 18
2.7 编译Scala 19
第3章 Scala步入正轨 20
3.1 把Scala当作简洁的Java 20
3.2 Java基本类型对应的Scala类 23
3.3 元组与多重赋值 23
3.4 字符串与多行原始字符串 25
3.5 自适应的默认做法 26
3.6 运算符重载 27
3.7 Scala带给Java程序员的惊奇 29
3.7.1 赋值的结果 29
3.7.2 Scala的== 30
3.7.3 分号是半可选的 31
3.7.4 默认的访问修饰符 32
3.7.5 默认的访问修饰符以及如何修改 32
3.7.6 Scala的Protected 33
3.7.7 细粒度访问控制 34
3.7.8 避免显式return 35
第4章 Scala的类 37
4.1 创建类 37
4.2 定义字段、方法和构造函数 38
4.3 类继承 41
4.4 单例对象 42
4.5 独立对象和伴生对象 43
4.6 Scala中的static 44
第5章 自适应类型 46
5.1 容器和类型推演 47
5.2 Any类型 49
5.3 关于Nothing的更多情况 50
5.4 Option类型 50
5.5 方法返回类型推演 51
5.6 传递变参 52
5.7 参数化类型的可变性 53
第6章 函数值和闭包 57
6.1 从普通函数迈向高阶函数 57
6.2 函数值 58
6.3 具有多参数的函数值 59
6.4 Curry化 61
6.5 重用函数值 62
6.6 参数的位置记法 64
6.7 Execute Around Method模式 65
6.8 偏应用函数 67
6.9 闭包 68
第7章 Trait和类型转换 70
7.1 Trait 70
7.2 选择性混入 72
7.3 以trait进行装饰 74
7.4 Trait方法的延迟绑定 75
7.5 隐式类型转换 77
第8章 使用容器 81
8.1 常见的Scala容器 81
8.2 使用Set 82
8.3 使用Map 83
8.4 使用List 85
8.5 for表达式 90
第9章 模式匹配和正则表达式 93
9.1 匹配字面量和常量 93
9.2 匹配通配符 94
9.3 匹配元组和列表 94
9.4 类型和卫述句的匹配 96
9.5 case表达式里的模式变量和常量 96
9.6 对XML片段进行模式匹配 98
9.7 使用case类进行模式匹配 98
9.8 使用提取器进行匹配 100
9.9 正则表达式 103
9.10 把正则表达式当做提取器 104
第10章 并发编程 106
10.1 促进不变性 106
10.2 使用Actor的并发 107
10.3 消息传递 110
10.4 Actor类 113
10.5 actor方法 115
10.6 receive和receiveWithin方法 117
10.7 react和reactWithin方法 120
10.8 loop和loopWhile 124
10.9 控制线程执行 125
10.10 在各种接收方法中选择 127
第11章 与Java互操作 128
11.1 在Scala里使用Scala类 128
11.2 在Scala里使用Java类 130
11.3 在Java里使用Scala类 132
11.3.1 有普通函数和高阶函数的Scala类 132
11.3.2 同trait一起工作 134
11.3.3 单例对象和伴生对象 134
11.4 继承类 136
第12章 用Scala做单元测试 138
12.1 使用JUnit 138
12.2 使用ScalaTest 139
12.3 以Canary测试开始 140
12.4 使用Runner 140
12.5 Asserts 142
12.6 异常测试 144
12.7 在测试间共享代码 146
12.7.1 用BeforeAndAfter共享代码 146
12.7.2 用闭包共享代码 147
12.8 FunSuite的函数式风格 148
12.9 用JUnit运行ScalaTest 149
第13章 异常处理 152
13.1 异常处理 152
13.2 注意catch顺序 154
第14章 使用Scala 156
14.1 净资产应用实例 156
14.2 获取用户输入 156
14.3 读写文件 157
14.4 XML,作为一等公民 159
14.5 读写XML 161
14.6 从Web获取股票价格 164
14.7 让净资产应用并发 167
14.8 为净资产应用增加GUI 168
附录A Web资源 178
· · · · · · (收起)
"Scala程序设计"试读 · · · · · ·
初涉代码之时,我的关注点在于实现功能。初窥门径的我,不了解语言,不熟悉常见的编码技巧。那时,只要代码能够跑出想要的效果,我便欣喜若狂,无暇顾及其他。 积累一定经验之后,对于编写代码,我越来越有感觉,实现一个功能不再高不可攀。我开始了解在工程中编写代码,如何在一个系统而不仅仅是一个局部处理问题,如何解决各种bug,更重要的是,从中汲取教训,在编码中避免这些问题。 ...
丛书信息
· · · · · ·
喜欢读"Scala程序设计"的人也喜欢的电子书 · · · · · ·
喜欢读"Scala程序设计"的人也喜欢 · · · · · ·
- Java并发编程 8.6
- JAVA并发编程实践 8.8
- 深入理解Java虚拟机 8.6
- 敏捷软件开发 9.1
- 深入Java虚拟机(原书第2版) 8.7
- 版本控制之道 7.7
- Python高级编程 7.6
Scala程序设计的书评 · · · · · · ( 全部 9 条 )
不推荐入门,介绍的太跳跃,粗
是一本让Java程序员迅速学会Scala的好书
> 更多书评 9篇
论坛 · · · · · ·
Scala程序设计:Java虚拟机多核编程实战 样张试读 | 来自互动出版网 | 1 回应 | 2010-08-25 15:52:29 |
翻译的还可以 | 来自红眼睛阿义 | 2010-08-17 16:49:19 | |
选择翻译这本呀 | 来自JamesQiu | 3 回应 | 2010-08-13 14:02:21 |
java人了解fp的窗户 | 来自netfishx | 2010-08-10 20:40:08 | |
一出世就过时了. | 来自焦靖 | 1 回应 | 2010-08-04 12:51:54 |
这本书的其他版本 · · · · · · ( 全部2 )
-
Pragmatic Bookshelf (2009)7.4分 33人读过
在哪儿借这本书 · · · · · ·
以下书单推荐 · · · · · · ( 全部 )
谁读这本书? · · · · · ·
二手市场
· · · · · ·
订阅关于Scala程序设计的评论:
feed: rss 2.0
1 有用 TerabyteX 2015-10-16 10:57:59
不学Scala的两个理由:1.Scala朝着错误的方向发展,它要做到大而全,导致语言越来越复杂,学习成本高。2.Scala是java平台的语言,必然用到jdk,设计糟糕的jdk,api设计得很差;实际工作中,涉及到业务系统时,用到的语言和框架,请远离java平台!
0 有用 Steven🇺🇦 2014-07-08 10:31:41
想看akka,无奈还是觉得学scala生产效率才能提升,一直没怎么实践过,这本书入门不错~
0 有用 散关清渭 2013-08-25 22:29:02
这本书原来看过一遍 大概是大四的时候 当时没有理解函数编程的含义 现在略有所悟 此书内容深刻 容量很大 文字流畅 毫不做作 比较了Java与Scala的异同 句句切中要害 难得的好书
0 有用 杜魚 2012-08-16 08:57:40
仅仅是学习是不够的,还需要多做项目。另外,关于Scala的书籍好像还是少了点。
0 有用 caibinbupt 2011-11-21 11:30:32
因为Spark里用了Scale才看的这本书,UCB的牛就是猛。很多概念,如闭包、actor以前也接触过,也就没有什么感觉,不太喜欢Scala(包括Ruby)里面的语法糖,书很薄,内容太少。
0 有用 Fenn 2022-02-14 12:19:27
翻完了,大概也不会再用了,scala靠的还是要大量实践
0 有用 牛晋 2020-06-19 02:00:59
学完只能对Scala 初窥门径,还不足以应用
0 有用 huixie 2018-07-12 11:51:38
比很多8分以上的好。主要是讲Scala语言,非多线程。原理性总结的不错
0 有用 云涛 2017-08-27 12:34:11
2010想读,直到2017才真的用scala些代码,,而且也是因为spark用scala实现的。没想看过和又机会动手用隔着那么远的距离。那个年代我还是一个好爱学习的孩子,现在已经是中年大叔了
0 有用 reverie 2017-07-12 23:38:05
还成 写惯了FP...就不想碰任何其他语言了