第1章 简介 1
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
· · · · · · (
收起)
评分
☆☆☆☆☆
快速入门。。。写出java式的scala,不着急用的童鞋可以略过这本,直接看programming in scala
评分
☆☆☆☆☆
因为Spark里用了Scale才看的这本书,UCB的牛就是猛。很多概念,如闭包、actor以前也接触过,也就没有什么感觉,不太喜欢Scala(包括Ruby)里面的语法糖,书很薄,内容太少。
评分
☆☆☆☆☆
有点(副)标题党 ...
评分
☆☆☆☆☆
魔化太多
评分
☆☆☆☆☆
口袋书,枕边书,如厕书,入门必备
评分
☆☆☆☆☆
Scala中文方面的资料很少,这本虽然老一点不过相当不错,至少比官方文档好理解得多,把很多坑跟Java的异同点都说得很清楚(这一点相当重要)。由于Scala是基于JVM的,本书也提到很多Java的东西所以最好还是有点Java基础,不过话说回来说不定不被Java影响可能学得更好? 以下是...
评分
☆☆☆☆☆
目标读者定位很明确,就是帮助Java程序员熟悉Scala语言。 可能是由于Scala的确有很多新颖(或者说不太适应)的东西,加上一些概念还没有标准化翻译,所以感觉还是稍欠打磨。 不过这本书还是推荐作为Scala入门书籍,对初接触Scala的人来说,还是很不错。 另外,我觉得译作加上...
评分
☆☆☆☆☆
快速入门书,没看完呢,不过觉得译者有点刻意想让读者知道自己看懂了原文的感觉,有点别扭,而且经常是通过无意义的脚注来说明他们看懂了,不喜欢这种做法。
评分
☆☆☆☆☆
目标读者定位很明确,就是帮助Java程序员熟悉Scala语言。 可能是由于Scala的确有很多新颖(或者说不太适应)的东西,加上一些概念还没有标准化翻译,所以感觉还是稍欠打磨。 不过这本书还是推荐作为Scala入门书籍,对初接触Scala的人来说,还是很不错。 另外,我觉得译作加上...
评分
☆☆☆☆☆
很薄而有精炼的一本书,通过ipad在上班的地铁上把这本书E文版看完了。一个Java程序员,看完一遍,基本上可以比较顺利的使用Scala了写程序了。有了Scala,你还会期待慢腾腾的Java 7,8,9,10..的新特性么?打算在一些小的项目、工具和机器学习的实验代码中使用并熟悉scala语言。对...