0%

Clojure编程乐趣

基本信息

名称: Clojure编程乐趣
作者信息: 作者: 福格斯 (Michael Fogus) [ 英文 pdf ]

简单介绍

如果曾亲见数十行JAVA活ruby浓缩成寥寥数行clojure代码,你便不难理解为何本书作者称clojure为一种有趣的语言。《Clojure编程乐趣》包括以下内容:●● 什么是Clojure 以及为什么要使用Clojure;●● 如何使用宏;●● 如何做出优雅的应用设计;●● 函数式编程惯用法。如果你是具有其他程序设计背景的程序员,那么《Clojure编程乐趣》就是为你而编写的。你无需Clojure 和Lisp 的经验。

目录

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
第1部分 基础
第1章 Clojure哲学
1.1 Clojure之道
1.1.1 简单
1.1.2 专注
1.1.3 实用
1.1.4 清晰
1.1.5 一致
1.2 为何(又一种)Lisp
1.2.1 优美
1.2.2 极度灵活
1.2.3 代码即数据
1.3 函数式编程
1.3.1 一个可行的函数式编程定义
1.3.2 函数式编程的内涵
1.4 Clojure为何不是面向对象的
1.4.1 定义术语
1.4.2 命令式“烘烤”
1.4.3 OOP提供的大多数东西,Clojure也有
1.5 小结
第2章 Clojure疾风式教程
2.1 标量
2.1.1 数字
2.1.2 整数
2.1.3 浮点数
2.1.4 有理数
2.1.5 符号
2.1.6 关键字
2.1.7 字符串
2.1.8 字符
2.2 组合起来:集合
2.2.1 list
2.2.2 vector
2.2.3 map
2.2.4 set
2.3 付诸实现:函数
2.3.1 调用函数
2.3.2 定义函数
2.3.3 用def和defn简化函数定义
2.3.4 以#()定义原位(in—place)函数
2.4 var
2.5 局部量、循环和block
2.5.1 block
2.5.2 局部量
2.5.3 循环
2.6 防止发生:quote
2.6.1 求值
2.6.2 quote
2.6.3 反quote
2.6.4 反quote拼接
2.6.5 auto—gensym
2.7 与Java互操作
2.7.1 访问静态类成员
2.7.2 创建Java实例
2.7.3 用运算符访问Java实例成员
2.7.4 设置Java实例属性
2.7.5 …宏
2.7.6 doto宏
2.7.7 定义类
2.8 异常环境
2.9 命名空间
2.9.1 用ns创建命名空间
2.9.2 用:require加载其他命名空间
2.9.3 用:use加载和创建映射
2.9.4 用:refer创建映射
2.9.5 用:import加载Java类
2.10 小结
第3章 小试牛刀
3.1 真值
3.1.1 什么是真
3.1.2 不要创建布尔对象
3.1.3 nil vs.false
3.2 小心翼翼nil双关
3.3 解构
3.3.1 你的任务,你应该选择接受
3.3.2 解构vector
3.3.3 解构map
3.3.4 解构函数参数
3.3.5 解构vs.访问器方法
3.4 用REPL做试验
3.4.1 试验seq
3.4.2 试验图形化
3.4.3 知识汇总
3.4.4 出错之时
3.4.5 只为乐趣
3.5 小结
第2部分 数据类型
第4章 标量
4.1 理解精度
4.1.1 截断(Truncation)
4.1.2 提升(Promotion)
4.1.3 上溢(Overflow)
4.1.4 下溢(Underflow)
4.1.5 舍入错误(Rounding errors)
4.2 有理数
4.2.1 为什么是有理数
4.2.2 怎样才是有理数
4.2.3 有理数的合理性
4.3 使用关键字的时机
4.3.1 关键字与符号有怎样的差别
4.3.2 限定关键字
4.4 符号解析
4.4.1 元数据
4.4.2 符号与命名空间
4.4.3 Lisp—1
4.5 正则表达式——第二个问题
4.5.1 语法
4.5.2 函数
4.5.3 小心可变匹配器(matcher)
4.6 总结
第5章 组合数据类型
5.1 持久化、序列和复杂度
5.1.1 “你一直用着这个词。我认为,这并不意味着它就是你以为的含义”
5.1.2 序列术语及其含义
5.1.3 大O
5.2 vector:创建和使用其各种变体
5.2.1 构建vector
5.2.2 大vector
5.2.3 vector当做栈
5.2.4 使用vector而非reverse
5.2.5 子vector
5.2.6 vector当做MapEntry
5.2.7 vector不是什么
5.3 list:Clojure代码form的数据结构
5.3.1 像Lisp那样的list
5.3.2 list当做栈
5.3.3 list不是什么
5.4 如何使用持久化队列
5.4.1 什么都没有的队列
5.4.2 入队
5.4.3 获取
5.4.4 出队
5.5 持久化set
5.5.1 Clojure set的基本属性
5.5.2 用sorted—set保持set的顺序
5.5.3 contains?
5.5.4 clojure.set
5.6 思考map
5.6.1 hash map
5.6.2 以有序map保持键值的顺序
5.6.3 用数组map保持插入顺序
5.7 知识汇总:在序列里查找某项的位置
5.8 小结
第3部分 函数式编程
第6章 惰性与不变性
6.1 关于不变性
6.1.1 定义不变性
6.1.2 固步自封—不变性
6.2 设计一个持久化玩具
6.3 惰性
6.3.1 以“逻辑与”熟悉惰性
6.3.2 理解lazy—seq的秘诀
6.3.3 丢掉头
6.3.4 采用无限序列
6.3.5 delay和force宏
6.3.6 知识汇总:一个惰性的快速排序程序
6.4 小结
第7章 函数式编程
7.1 各种形式的函数
7.1.1 一等函数
7.1.2 高阶函数
7.1.3 纯函数
7.1.4 命名实参
7.1.5 使用前置条件和后置条件约束函数
7.2 闭包
7.3 递归思考
7.3.1 普通递归
7.3.2 尾递归和recur
7.3.3 勿忘trampoline
7.3.4 延续传递风格
7.4 知识汇总:A寻路 7.4.1 A实现
7.4.2 A*实现的笔记
7.5 小结
第4部分 大规模设计
第8章 宏
8.1 数据即代码即数据
8.1.1 语法quote、反quote和拼接
8.1.2 宏之经验谈
8.2 定义控制结构
8.2.1 不用语法quote定义控制结构
8.2.2 使用语法quote和反quote定义控制结构
8.3 组合form的宏
8.4 使用宏改变form
8.5 使用宏控制符号解析
8.5.1 回指
8.5.2 (具有争议地)有用的选择性名字捕获
8.6 使用宏管理资源
8.7 知识汇总:返回函数的宏
8.8 小结
第9章 组合数据与代码
9.1 命名空间
9.1.1 创建命名空间
9.1.2 只暴露所需
9.1.3 声明性包含和排除
9.2 以通用设计模式探索Clojure多重方法
9.2.1 组成部分
9.2.2 用法
9.2.3 以多重方法拯救
9.2.4 处理继承行为的特别继承
9.2.5 解析层次中的冲突
9.2.6 真正的最大功率任意分发
9.3 类型、协议和记录
9.3.1 记录
9.3.2 协议
9.3.3 用deftype从更原始的基础开始构建
9.4 知识汇总:国际象棋移动的流畅构建器
9.4.1 Java实现
9.4.2 Clojure实现
9.5 小结
第10章 Java.next
10.1 使用proxy动态生成对象
10.2 Clojure gen—class和GUI程序设计
10.2.1 命名空间作为类的规范
10.2.2 以Clojure探索用户界面设计与开发
10.3 Clojure同Java数组的关系
10.3.1 数组的类型:原生与引用
10.3.2 数组可变性
10.3.3 那个不幸的命名约定
10.3.4 多维数组
10.3.5 调用可变方法/构造函数
10.4 所有Clojure函数都实现
10.4.1 java.util.Comparator
10.4.2 java.lang.Runnable
10.4.3 java.util.concurrent.Callable
10.5 在Java API里使用Clojure数据结构
10.5.1 java.util.List
10.5.2 java.lang.Comparable
10.5.3 java.util.RandomAccess
10.5.4 java.util.Collection
10.5.5 java.util.Set
10.6 definterface
10.7 慎用异常
10.7.1 一点异常的背景
10.7.2 运行时异常vs.编译时异常
10.7.3 处理异常
10.7.4 定制异常
10.8 小结
第11章 变化
11.1 软件事务性内存,包括多版本并发控制和快照隔离
11.1.1 事务
11.1.2 嵌入式事务
11.1.3 STM使其简单的事情
11.1.4 潜在缺陷
11.1.5 让STM不高兴的事
11.2 使用Ref的时机
11.2.1 使用alter进行可协调的、同步的改变
11.2.2 以commute进行可交换的改变
11.2.3 以ref—set进行普通改变
11.2.4 用ensure修正写入偏差
11.2.5 压力之下的Ref
11.3 使用Agent的时机
11.3.1 进程内并发模型vs分布式并发模型
11.3.2 用Agent控制I/O
11.3.3 send和send—off之间的差异
11.3.4 错误处理
11.3.5 何时不用Agent
11.4 使用Atom的时机
11.4.1 跨线程共享
11.4.2 在事务里使用Atom
11.5 使用lock的时机
11.5.1 使用锁进行安全变化
11.5.2 使用Java的显式锁
11.6 使用future的时机
11.7 使用promise的时机
11.7.1 以promise进行并行任务
11.7.2 回调API到阻塞API
11.7.3 确定性死锁
11.8 并行
11.8.1 pvalues
11.8.2 pmap
11.8.3 pcalls
11.9 var和动态绑定
11.9.1 binding宏
11.9.2 创建命名var
11.9.3 创建匿名var
11.9.4 动态作用域
11.10 小结
……
第5部分 杂项考量

亚马逊链接

欢迎关注我的其它发布渠道