-
>
決戰(zhàn)行測(cè)5000題(言語(yǔ)理解與表達(dá))
-
>
軟件性能測(cè)試.分析與調(diào)優(yōu)實(shí)踐之路
-
>
第一行代碼Android
-
>
深度學(xué)習(xí)
-
>
Unreal Engine 4藍(lán)圖完全學(xué)習(xí)教程
-
>
深入理解計(jì)算機(jī)系統(tǒng)-原書(shū)第3版
-
>
Word/Excel PPT 2013辦公應(yīng)用從入門(mén)到精通-(附贈(zèng)1DVD.含語(yǔ)音視頻教學(xué)+辦公模板+PDF電子書(shū))
函數(shù)式與并發(fā)編程 版權(quán)信息
- ISBN:9787302672173
- 條形碼:9787302672173 ; 978-7-302-67217-3
- 裝幀:平裝-膠訂
- 冊(cè)數(shù):暫無(wú)
- 重量:暫無(wú)
- 所屬分類(lèi):>>
函數(shù)式與并發(fā)編程 本書(shū)特色
《函數(shù)式與并發(fā)編程》主要圍繞兩個(gè)主題:函數(shù)式編程和并發(fā)編程。本書(shū)主要使用Scala 編寫(xiě)代碼示例,逐一講解各編程特性的用法和注意事項(xiàng),是一本不可多得的工具書(shū),強(qiáng)烈推薦給程序員們。筆者周?chē)某绦騿T提到這兩個(gè)主題時(shí)都存在一定的畏難情緒,這是正常的,也是可以理解的。程序員不僅需要豐富的編程經(jīng)驗(yàn),還要具備深厚的編程設(shè)計(jì)思維,而這并非一朝一夕就能形成的,需要經(jīng)年累月的實(shí)戰(zhàn)和經(jīng)驗(yàn)積累。我并不推薦讀者將本書(shū)從頭讀到尾,這樣不利于理解和消化書(shū)中的知識(shí)點(diǎn)。建議具備一定的函數(shù)式編程和并發(fā)編程基礎(chǔ)的讀者建立場(chǎng)景和問(wèn)題,通過(guò)解決問(wèn)題的方式來(lái)學(xué)習(xí)本書(shū),并在遇到問(wèn)題時(shí)查閱本書(shū)。本書(shū)也可作為理解這兩個(gè)主題的途徑。
函數(shù)式與并發(fā)編程 內(nèi)容簡(jiǎn)介
"現(xiàn)代語(yǔ)言支持的函數(shù)式和并發(fā)編程語(yǔ)言特性可能富有挑戰(zhàn)性,即使是經(jīng)驗(yàn)豐富的開(kāi)發(fā)人員,當(dāng)面對(duì)函數(shù)式與并發(fā)編程時(shí),也可能心生畏懼。面向?qū)ο缶幊痰某绦騿T之所以畏懼這些特性,很可能是因?yàn)樗麄儗?duì)這些特性的工作方式有所誤解。為了消除誤解,程序員應(yīng)首先熟悉這些強(qiáng)大的特性背后的抽象概念。 《函數(shù)式與并發(fā)編程》介紹了一系列核心的編程語(yǔ)言結(jié)構(gòu),可讓你的編程工作變得高效起來(lái),無(wú)論你使用的是哪種編程語(yǔ)言,你都能從中獲益——在當(dāng)下的工作中,以及在未來(lái)的職業(yè)發(fā)展中。Charpentier用大量重點(diǎn)突出的小型Scala代碼示例闡釋了函數(shù)式與并發(fā)編程的關(guān)鍵概念,并通過(guò)完整的案例研究對(duì)前述技術(shù)和技巧進(jìn)行深入的探究和闡釋。這些技術(shù)和技巧將從一種語(yǔ)言傳遞到另一種語(yǔ)言——包括Java的**版本。利用函數(shù)式和并發(fā)編程語(yǔ)言特性,開(kāi)發(fā)人員和程序員將能編寫(xiě)出易于理解、調(diào)試、優(yōu)化和改進(jìn)的優(yōu)質(zhì)代碼。 另外,本書(shū)還討論了現(xiàn)代編程語(yǔ)言中常用的類(lèi)型策略,包括類(lèi)型推斷、子類(lèi)型、多態(tài)性、類(lèi)型類(lèi)、類(lèi)型邊界和變型。 核心主題 ● 遞歸和尾遞歸 ● 模式匹配和代數(shù)數(shù)據(jù)類(lèi)型 ● 可持久化結(jié)構(gòu)和不可變性 ● 高階函數(shù)和lambda表達(dá)式 ● 延遲求值和流 ● 線程和線程池 ● 原子性和鎖 ● 同步和線程安全對(duì)象 ● 無(wú)鎖、非阻塞模式 ● Future、Promise和函數(shù)并發(fā)編程 《函數(shù)式與并發(fā)編程》中的大部分代碼示例都是使用Scala編寫(xiě)的,其中包含函數(shù)式與并發(fā)編程的許多標(biāo)準(zhǔn)特性;然而,讀者不必事先了解Scala,而只需要熟悉一些基本概念,如類(lèi)、方法、對(duì)象、類(lèi)型、變量、循環(huán)和條件語(yǔ)句等。此外,讀者在編程方面應(yīng)有足夠的經(jīng)驗(yàn),以免因?yàn)楹?jiǎn)單的語(yǔ)法問(wèn)題而分心。 "
函數(shù)式與并發(fā)編程 目錄
第1章 函數(shù)式編程的概念 3
1.1 什么是函數(shù)式編程 3
1.2 函數(shù) 4
1.3 從函數(shù)到函數(shù)式編程概念 5
1.4 小結(jié) 6
第2章 編程語(yǔ)言中的函數(shù) 7
2.1 定義函數(shù) 7
2.2 合成函數(shù) 8
2.3 定義為方法的函數(shù) 9
2.4 定義為方法的運(yùn)算符 10
2.5 擴(kuò)展方法 10
2.6 局部函數(shù) 11
2.7 重復(fù)參數(shù) 12
2.8 可選參數(shù) 13
2.9 命名參數(shù) 13
2.10 類(lèi)型參數(shù) 14
2.11 小結(jié) 16
第3章 不可變性 17
3.1 純函數(shù)和非純函數(shù) 17
3.2 動(dòng)作 18
3.3 表達(dá)式與語(yǔ)句 20
3.4 函數(shù)變量 22
3.5 不可變對(duì)象 23
3.6 可變狀態(tài)的實(shí)現(xiàn) 24
3.7 函數(shù)式列表 25
3.8 混合編程 27
3.9 更新可變/不可變對(duì)象的集合 28
3.10 小結(jié) 30
第4章 案例研究:active-passive集合 31
4.1 面向?qū)ο笤O(shè)計(jì) 31
4.2 函數(shù)值 33
4.3 函數(shù)對(duì)象 35
4.4 小結(jié) 36
第5章 模式匹配與代數(shù)數(shù)據(jù)類(lèi)型 38
5.1 函數(shù)開(kāi)關(guān) 38
5.2 元組 39
5.3 選項(xiàng) 40
5.4 回顧函數(shù)式列表 41
5.5 樹(shù) 43
5.6 示例:列表拉鏈 46
5.7 提取器 48
5.8 小結(jié) 49
第6章 遞歸程序設(shè)計(jì) 51
6.1 遞歸的必要性 51
6.2 遞歸算法 53
6.3 遞歸算法的關(guān)鍵原理 55
6.4 遞歸結(jié)構(gòu) 56
6.5 尾遞歸 58
6.6 尾遞歸函數(shù)示例 60
6.7 小結(jié) 63
第7章 列表遞歸 64
7.1 等價(jià)的遞歸算法 64
7.2 遍歷列表 65
7.3 返回列表 66
7.4 從執(zhí)行堆棧中構(gòu)建列表 68
7.5 多個(gè)/嵌套列表上的遞歸 69
7.6 除尾部以外的子列表遞歸 71
7.7 逆序創(chuàng)建列表 73
7.8 示例:排序 74
7.9 高效地構(gòu)建列表 77
7.10 小結(jié) 78
第8章 案例研究:二叉搜索樹(shù) 79
8.1 二叉搜索樹(shù) 79
8.2 二叉搜索樹(shù)的整數(shù)集 80
8.3 未重新平衡情況下的實(shí)現(xiàn) 81
8.4 自平衡樹(shù) 86
8.5 小結(jié) 90
第9章 高階函數(shù) 92
9.1 函數(shù)作為值 92
9.2 柯里化 95
9.3 函數(shù)字面量 96
9.4 函數(shù)與方法 99
9.5 單一抽象方法接口 100
9.6 部分應(yīng)用 100
9.7 閉包 104
9.8 控制反轉(zhuǎn) 107
9.9 小結(jié) 108
第10章 標(biāo)準(zhǔn)高階函數(shù) 109
10.1 帶有謂詞參數(shù)的函數(shù) 109
10.2 映射和遍歷 111
10.3 flatMap 112
10.4 fold和reduce 116
10.5 iterate、tabulate和unfold 118
10.6 sortWith、sortBy、maxBy和minBy 119
10.7 groupBy和groupMap 120
10.8 標(biāo)準(zhǔn)高階函數(shù)的實(shí)現(xiàn) 121
10.9 foreach、map、flatMap和for推導(dǎo)式 122
10.10 小結(jié) 124
第11章 案例研究:文件樹(shù) 125
11.1 設(shè)計(jì)概述 125
11.2 節(jié)點(diǎn)搜索輔助函數(shù) 126
11.3 字符串表示 126
11.4 構(gòu)建樹(shù) 128
11.5 查詢 131
11.6 導(dǎo)航 135
11.7 樹(shù)形拉鏈 135
11.8 小結(jié) 138
第12章 延遲計(jì)算 139
12.1 延遲求值的參數(shù) 139
12.2 按名稱(chēng)參數(shù) 140
12.3 控制抽象 142
12.4 內(nèi)部領(lǐng)域特定語(yǔ)言 144
12.5 作為延遲求值列表的流 145
12.6 管道流 147
12.7 無(wú)限數(shù)據(jù)結(jié)構(gòu)流 148
12.8 迭代 149
12.9 列表、流、迭代程序和視圖 151
12.10 字段和局部變量的延遲求值 154
12.11 示例:子集和 155
12.12 小結(jié) 157
第13章 故障處理 158
13.1 例外情況和特殊值 158
13.2 使用Option 160
13.3 使用Try 160
13.4 使用Either 162
13.5 高階函數(shù)和管道 163
13.6 小結(jié) 166
第14章 案例研究:蹦床 167
14.1 尾調(diào)用優(yōu)化 167
14.2 用于尾調(diào)用的蹦床函數(shù) 168
14.3 Java中的尾調(diào)用優(yōu)化 169
14.4 處理非尾調(diào)用 170
14.5 小結(jié) 174
第15章 類(lèi)型(及相關(guān)概念) 175
15.1 類(lèi)型策略 175
15.2 類(lèi)型集合 179
15.3 類(lèi)型服務(wù) 180
15.4 抽象數(shù)據(jù)類(lèi)型 181
15.5 類(lèi)型推斷 182
15.6 子類(lèi)型 185
15.7 多態(tài)性 188
15.8 類(lèi)型變換 190
15.9 類(lèi)型邊界 195
15.10 類(lèi)型類(lèi) 199
15.11 小結(jié) 203
第Ⅱ部分 并發(fā)編程
第16章 并發(fā)編程的概念 208
16.1 非順序程序 208
16.2 并發(fā)編程相關(guān)概念 211
16.3 小結(jié) 211
第17章 線程與不確定性 213
17.1 執(zhí)行線程 213
17.2 使用lambda表達(dá)式創(chuàng)建線程 214
17.3 多線程程序的不確定性 215
17.4 線程終止 216
17.5 測(cè)試和調(diào)試多線程程序 218
17.6 小結(jié) 219
第18章 原子性和鎖 220
18.1 原子性 220
18.2 非原子操作 222
18.3 原子操作和非原子復(fù)合操作 223
18.4 鎖 226
18.5 內(nèi)部鎖 227
18.6 選擇鎖目標(biāo) 229
18.7 小結(jié) 231
第19章 線程安全對(duì)象 232
19.1 不可變對(duì)象 232
19.2 封裝同步策略 233
19.3 避免引用轉(zhuǎn)義 234
19.4 公用鎖和私有鎖 235
19.5 利用不可變類(lèi)型 236
19.6 線程安全 239
19.7 小結(jié) 240
第20章 案例研究:線程安全隊(duì)列 242
20.1 作為列表對(duì)組的隊(duì)列 242
20.2 單個(gè)公用鎖的實(shí)現(xiàn) 242
20.3 單個(gè)私有鎖的實(shí)現(xiàn) 245
20.4 應(yīng)用鎖拆分 247
20.5 小結(jié) 249
第21章 線程池 250
21.1 即發(fā)即棄異步執(zhí)行 250
21.2 示例:并行服務(wù)器 252
21.3 不同類(lèi)型的線程池 254
21.4 并行集合 256
21.5 小結(jié) 260
第22章 同步 261
22.1 同步的必要性 261
22.2 同步器 264
22.3 死鎖 265
22.4 使用線程轉(zhuǎn)儲(chǔ)調(diào)試死鎖 267
22.5 Java內(nèi)存模型 268
22.6 小結(jié) 272
第23章 常用同步器 274
23.1 鎖 274
23.2 鎖存器和柵欄 276
23.3 信號(hào)量 278
23.4 條件 279
23.5 阻塞隊(duì)列 284
23.6 小結(jié) 287
第24章 案例研究:并行執(zhí)行 289
24.1 順序引用實(shí)現(xiàn) 289
24.2 每個(gè)任務(wù)一個(gè)新線程 290
24.3 有界線程數(shù) 291
24.4 專(zhuān)用線程池 292
24.5 共享線程池 293
24.6 有界線程池 294
24.7 并行集合 295
24.8 使用條件提交異步任務(wù) 295
24.9 雙信號(hào)量實(shí)現(xiàn) 299
24.10 小結(jié) 300
第25章 Future與Promise 302
25.1 函數(shù)任務(wù) 302
25.2 Future作為同步器 303
25.3 超時(shí)、故障和取消 306
25.4 Future變體 307
25.5 Promise 308
25.6 示例:線程安全緩存 309
25.7 小結(jié) 311
第26章 函數(shù)并發(fā)編程 312
26.1 阻塞的正確性和性能問(wèn)題 312
26.2 回調(diào) 314
26.3 Future的高階函數(shù) 316
26.4 Future的flatMap函數(shù) 318
26.5 示例:重新訪問(wèn)并行服務(wù)器 319
26.6 函數(shù)并發(fā)編程模式 322
26.7 小結(jié) 325
第27章 *小化線程阻塞 327
27.1 原子操作 327
27.2 無(wú)鎖數(shù)據(jù)結(jié)構(gòu) 330
27.3 fork/join池 332
27.4 異步編程 333
27.5 actor 334
27.6 反應(yīng)流 337
27.7 非阻塞同步 338
27.8 小結(jié) 340
第28章 案例研究:并行策略 341
28.1 問(wèn)題定義 341
28.2 帶超時(shí)的順序?qū)崿F(xiàn) 342
28.3 使用invokeAny的并行實(shí)現(xiàn) 344
28.4 使用CompletionService的并行實(shí)現(xiàn) 345
28.5 Scala Future的異步實(shí)現(xiàn) 346
28.6 帶有CompletableFuture的異步實(shí)現(xiàn) 348
28.7 緩存策略的結(jié)果 350
28.8 小結(jié) 353 —附錄和詞匯表通過(guò)掃描封底二維碼獲取—
附錄 Java和Kotlin的特性 354
詞匯表 381
函數(shù)式與并發(fā)編程 作者簡(jiǎn)介
Michel Charpentier 是美國(guó)新罕布什爾大學(xué)(UNH)計(jì)算機(jī)科學(xué)系的副教授。多年來(lái),他一直致力于分布式系統(tǒng)、正式驗(yàn)證以及移動(dòng)傳感器網(wǎng)絡(luò)等領(lǐng)域的研究。自 1999 年以來(lái),他一直在UNH工作,目前正在講授編程語(yǔ)言、并發(fā)性、形式驗(yàn)證和模型檢查等課程。
- >
企鵝口袋書(shū)系列·偉大的思想20:論自然選擇(英漢雙語(yǔ))
- >
有舍有得是人生
- >
經(jīng)典常談
- >
唐代進(jìn)士錄
- >
大紅狗在馬戲團(tuán)-大紅狗克里弗-助人
- >
煙與鏡
- >
苦雨齋序跋文-周作人自編集
- >
中國(guó)人在烏蘇里邊疆區(qū):歷史與人類(lèi)學(xué)概述