Scala编程(第3版)

Scala编程(第3版)

作者:【德】Martin Odersky(马丁.奥德斯基)

出版社:电子工业出版社

出版年:2018-1-1

评分:9.4

ISBN:9787121328428

所属分类:行业好书

书刊介绍

内容简介

Martin Odersky 是Scala 编程语言的缔造者。他是瑞士洛桑理工学院(EPFL)的教授,同时也是Typesafe, Inc.(已更名为Lightbend)的创始人。他的研究方向是编程语言和系统,更具体地说,就是如何将面向对象和函数式编程风格有机地结合在一起。自2001 年起,他的主要精力集中在设计、实现和改进Scala 上。在此之前,他作为Java 泛型的合作设计者参与了Java 编程语言的开发,同时也是当前javac 参考实现的作者。他还是ACM 院士。

Lex Spoon是Semmle Ltd 的一名软件工程师。他在EPFL 作为博士后围绕着Scala 开展了两年的工作。他拥有Georgia Tech 的博士学位,在那里他的主攻方向是动态编程语言的静态分析。除Scala 外,他还帮助开发了各类编程语言,包括动态语言Smalltalk...

()

作品目录

序.XXIV
致谢.XXVI
引言.XXIX
第1章 一门可伸缩的语言.1
1.1 一门按需伸缩的语言 2
1.2 是什么让Scala能屈能伸? 7
1.3 为什么要用Scala?.11
1.4 Scala寻根 17
1.5 结语 19
第2章 Scala入门 20
第1步 使用Scala解释器 21
第2步 定义变量 22
第3步 定义函数 24
第4步 编写Scala脚本 26
第5步 用while做循环;用if做判断 27
第6步 用foreach和for遍历 30
结语 32
第3章 Scala入门(续).33
第7步 用类型参数化数组 33
第8步 使用列表 38
第9步 使用元组 42
第10步使用集和映射 43
第11步 识别函数式编程风格 48
第12步 从文件读取文本行 51
结语 55
第4章 类和对象.56
4.1 类、字段和方法 56
4.2 分号推断 61
4.3 单例对象 62
4.4 Scala应用程序 65
4.5 App特质 68
4.6 结语 68
第5章 基础类型和操作69
5.1 一些基础类型 69
5.2 字面量 70
5.3 字符串插值 77
5.4 操作符即方法 78
5.5 算术操作 81
5.6 关系和逻辑操作 83
5.7 位运算操作 85
5.8 对象相等性 86
5.9 操作符优先级和结合性 88
5.10 富包装类 91
5.11 结语 91
第6章 函数式对象.93
6.1 Rational类的规格定义 93
6.2 构建Rational 94
6.3 重新实现toString方法 96
6.4 检查前置条件 97
6.5 添加字段 98
6.6 自引用.100
6.7 辅助构造方法.101
6.8 私有字段和方法.102
6.9 定义操作符 104
6.10 Scala中的标识符.106
6.11 方法重载.108
6.12 隐式转换.111
6.13 注意事项.112
6.14 结语 112
第7章 内建的控制结构 114
7.1 if表达式.115
7.2 while循环 116
7.3 for表达式 119
7.4 用try表达式实现异常处理125
7.5 match表达式129
7.6 没有break和continue的日子.131
7.7 变量作用域 134
7.8 对指令式代码进行重构.137
7.9 结语.139
第8章 函数和闭包 140
8.1 方法.140
8.2 局部函数142
8.3 一等函数144
8.4 函数字面量的简写形式.147
8.5 占位符语法 147
8.6 部分应用的函数.149
8.7 闭包.152
8.8 特殊的函数调用形式 156
8.9 尾递归.159
8.10 结语 163
第9章 控制抽象 164
9.1 减少代码重复.164
9.2 简化调用方代码.169
9.3 柯里化.170
9.4 编写新的控制结构173
9.5 传名参数176
9.6 结语.178
第10章 组合和继承179
10.1 一个二维的布局类库179
10.2 抽象类 180
10.3 定义无参方法 182
10.4 扩展类 184
10.5 重写方法和字段 186
10.6 定义参数化字段 188
10.7 调用超类构造方法.189
10.8 使用override修饰符 190
10.9 多态和动态绑定 192
10.10 声明final成员.195
10.11 使用组合和继承196
10.12 实现above、beside和toString.198
10.13 定义工厂对象.201
10.14 增高和增宽.204
10.15 放在一起 206
10.16 结语207
第11章 Scala的继承关系208
11.1 Scala的类继承关系208
11.2 基本类型的实现机制212
11.3 底类型(bottom types).215
11.4 定义自己的值类型.216
11.5 结语219
第12章 特质.220
12.1 特质如何工作 220
12.2 瘦接口和富接口 224
12.3 示例:矩形对象 225
12.4 Ordered特质 227
12.5 作为可叠加修改的特质229
12.6 为什么不用多重继承?234
12.7 要特质还是不要特质?238
12.8 结语 238
第13章 包和引入240
13.1 将代码放进包里 240
13.2 对相关代码的精简访问242
13.3 引入 246
13.4 隐式引入.249
13.5 访问修饰符250
13.6 包对象 256
13.7 结语 257
第14章 断言和测试258
14.1 断言 258
14.2 用Scala写测试 260
14.3 翔实的失败报告 262
14.4 作为规格说明的测试263
14.5 基于性质的测试 267
14.6 组织和运行测试 268
14.7 结语 270
第15章 样例类和模式匹配.271
15.1 一个简单的例子 271
15.2 模式的种类276
15.3 模式守卫.286
15.4 模式重叠.287
15.5 密封类 289
15.6 Option类型.291
15.7 到处都是模式 293
15.8 一个复杂的例子 298
15.9 结语 306
第16章 使用列表307
16.1 List字面量 307
16.2 List类型 308
16.3 构建列表.309
16.4 列表的基本操作 309
16.5 列表模式.310
16.6 List类的初阶方法 312
16.7 List类的高阶方法 324
16.8 List对象的方法333
16.9 同时处理多个列表.335
16.10 理解Scala的类型推断算法 336
16.11 结语.339
第17章 使用其他集合类 340
17.1 序列 340
17.2 集和映射.344
17.3 在可变和不可变集合类之间选择352
17.4 初始化集合355
17.5 元组 358
17.6 结语 361
第18章 可变对象362
18.1 什么样的对象是可变的? 362
18.2 可被重新赋值的变量和属性.365
18.3 案例分析:离散事件模拟 368
18.4 用于描述数字电路的语言 369
18.5 Simulation API.372
18.6 电路模拟.376
18.7 结语 384
第19章 类型参数化385
19.1 函数式队列385
19.2 信息隐藏.389
19.3 型变注解.392
19.4 检查型变注解 397
19.5 下界 400
19.6 逆变 402
19.7 对象私有数据 405
19.8 上界 407
19.9 结语 410
第20章 抽象成员 411
20.1 抽象成员概览 411
20.2 类型成员.412
20.3 抽象的val413
20.4 抽象的var414
20.5 初始化抽象的val.415
20.6 抽象类型.423
20.7 路径依赖类型 425
20.8 改良类型.428
20.9 枚举 429
20.10 案例分析:货币431
20.11 结语.441
第21章 隐式转换和隐式参数.442
21.1 隐式转换.442
21.2 隐式规则.445
21.3 隐式转换到一个预期的类型.448
21.4 转换接收端450
21.5 隐式参数.454
21.6 上下文界定460
21.7 当有多个转换可选时463
21.8 调试 465
21.9 结语 467
第22章 实现列表468
22.1 List类的原理.468
22.2 ListBuffer类 475
22.3 List类的实践.476
22.4 外部可见的函数式.479
22.5 结语 480
第23章 重访for表达式 481
23.1 for表达式483
23.2 N皇后问题.484
23.3 用for推导式进行查询 487
23.4 用for推导式进行翻译 489
23.5 反过来 494
23.6 泛化for表达式 495
23.7 结语 497
第24章 深入集合类498
24.1 可变和不可变集合.499
24.2 集合的一致性 501
24.3 Traversable特质 503
24.4 Iterable特质508
24.5 序列型特质Seq、IndexedSeq和LinearSeq.512
24.6 集517
24.7 映射 521
24.8 具体的不可变集合类525
24.9 具体的可变集合类.532
24.10 数组539
24.11 字符串544
24.12 性能特征 545
24.13 相等性547
24.14 视图548
24.15 迭代器554
24.16 从头创建集合.561
24.17 Java和Scala集合互转.563
24.18 结语564
第25章 Scala集合架构565
25.1 集合构建器565
25.2 抽取公共操作 567
25.3 集成新的集合 572
25.4 结语 588
第26章 提取器589
26.1 示例:提取电子邮箱地址 589
26.2 提取器 591
26.3 提取0或1个变量的模式 594
26.4 提取可变长度参数的模式 596
26.5 提取器和序列模式.598
26.6 提取器和样例类的对比599
26.7 正则表达式601
26.8 结语 604
第27章 注解.606
27.1 为什么要有注解?.606
27.2 注解的语法607
27.3 标准注解.609
27.4 结语 613
第28章 使用XML614
28.1 半结构化数据 614
28.2 XML概览615
28.3 XML字面量 616
28.4 序列化 618
28.5 拆解XML620
28.6 反序列化.622
28.7 加载和保存623
28.8 对XML做模式匹配624
28.9 结语 628
第29章 用对象实现模块化编程.629
29.1 问题描述.630
29.2 食谱应用程序 631
29.3 抽象 634
29.4 将模块拆分成特质.638
29.5 运行时链接640
29.6 跟踪模块实例 642
29.7 结语 643
第30章 对象相等性645
30.1 Scala中的相等性.645
30.2 编写相等性方法 646
30.3 为参数化类型定义相等性 660
30.4 如何编写equals和hashCode方法.664
30.5 结语 668
第31章 结合Scala和Java 669
31.1 从Java使用Scala.669
31.2 注解 672
31.3 通配类型.678
31.4 同时编译Scala和Java680
31.5 基于Scala 2.12特性的Java 8集成681
31.6 结语 685
第32章 Future和并发编程 686
32.1 天堂里的烦恼 687
32.2 异步执行和Try.688
32.3 使用Future.690
32.4 测试Future.705
32.5 结语 708
第33章 组合子解析709
33.1 示例:算术表达式.710
33.2 运行你的解析器 712
33.3 基本的正则表达式解析器 713
33.4 另一个示例:JSON 714
33.5 解析器输出717
33.6 实现组合子解析器.723
33.7 字符串字面量和正则表达式.732
33.8 词法分析和解析 733
33.9 错误报告.734
33.10 回溯和LL(1)736
33.11 结语.737
第34章 GUI编程.740
34.1 第一个Swing应用程序.740
34.2 面板和布局743
34.3 处理事件.745
34.4 示例:摄氏/华氏转换器.748
34.5 结语 750
第35章 SCells试算表 752
35.1 可视化框架752
35.2 将数据录入和显示分开755
35.3 公式 758
35.4 解析公式.760
35.5 求值 765
35.6 操作类库.768
35.7 变更通知.771
35.8 结语 775
附录A Unix和Windows环境的Scala脚本.777
关于作者 798
· · · · · ·

作者简介

Martin Odersky 是Scala 编程语言的缔造者。他是瑞士洛桑理工学院(EPFL)的教授,同时也是Typesafe, Inc.(已更名为Lightbend)的创始人。他的研究方向是编程语言和系统,更具体地说,就是如何将面向对象和函数式编程风格有机地结合在一起。自2001 年起,他的主要精力集中在设计、实现和改进Scala 上。在此之前,他作为Java 泛型的合作设计者参与了Java 编程语言的开发,同时也是当前javac 参考实现的作者。他还是ACM 院士。

Lex Spoon是Semmle Ltd 的一名软件工程师。他在EPFL 作为博士后围绕着Scala 开展了两年的工作。他拥有Georgia Tech 的博士学位,在那里他的主攻方向是动态编程语言的静态分析。除Scala 外,他还帮助开发了各类编程语言,包括动态语言Smalltalk...

(展开全部)

精彩摘录

AbouttheAuthorsMartinOderskyisthecreatoroftheScalalanguage.HeisaprofessoratEPFLinLausanne,Switzerland,andafounderofScalaSolutionsInc.Heworksonprogramminglanguagesandsystems,morespecificallyonthetopicofhowtocombineobject-orientedandfunctionalprogramming.Since2001hehasconcentratedondesigning,implementing,andrefiningScala.Previously,hehasinfluencedthedevelopmentofJavaasaco-designerofJavagenericsandastheoriginalauthorofthecurrentjavacreferencecompiler.HeisafellowoftheACM.LexSpoonisasoftwareengineeratLogicBlox,Inc.HeworkedonScalafortwoyearsasapost-docatEPFL.HehasaPh.D.incomputersciencefromGeorgiaTech,whereheworkedonstaticanalysisofdynamiclanguages.InadditiontoSca...

——引自第845页


scala>implicitdefintToRational(x:Int)=newRational(x)

——引自章节:Chapter6FunctionalObjects

相关推荐

微信二维码