Java實戰(第2版)

Java實戰(第2版) pdf epub mobi txt 電子書 下載2025

出版者:人民郵電齣版社
作者:[英] 拉烏爾-加布裏埃爾 • 烏爾瑪
出品人:
頁數:508
译者:陸明剛
出版時間:2019-11
價格:119.00元
裝幀:平裝
isbn號碼:9787115521484
叢書系列:圖靈程序設計叢書·Java係列
圖書標籤:
  • Java
  • 函數式編程
  • 編程
  • 計算機
  • 程序設計
  • 計算科學
  • CS
  • Java
  • 編程
  • 實戰
  • 第2版
  • 麵嚮對象
  • 企業應用
  • 開發學習
  • 核心技能
  • 編程語言
  • 軟件開發
想要找書就要到 小美書屋
立刻按 ctrl+D收藏本頁
你會得到大驚喜!!

具體描述

現代Java應用充分利用瞭微服務、反應式架構以及流式數據等創新設計。現代Java特性,譬如Lambda、流以及大傢期待已久的Java模塊係統讓這些設計的實現極其便利。是時候更新技能工具箱瞭,隻有這樣,你纔能從容應對迎麵而來的種種挑戰!

本書通過透徹的示例和通俗的語言講解瞭Java語言這些最激動人心的特性,作者注重細節,努力降低瞭學習難度,節省你寶貴的時間。依照本書邊學邊練,你可以很快掌握流應用程序接口、Java模塊係統等現代Java新特性,再進一步去探尋實現並發的新方法,瞭解函數式編程如何幫你編寫可讀性好又容易維護的代碼。潛心修煉,你的編程實力必能提高到新的層次。

本書特色:

●對上一版(《Java 8實戰》)做瞭全新改版

●Java 8、9、10及後續版本新特性介紹

●流數據處理以及反應式編程

●Java模塊係統

著者簡介

作者簡介:

拉烏爾–加布裏埃爾•烏爾瑪(Raoul-Gabriel Urma)

劍橋大學計算機科學博士,軟件工程師,培訓師,現任Cambridge Spark公司CEO。在榖歌、eBay、甲骨文和高盛等大公司工作過,並參與過多個創業項目。活躍在技術社區,經常撰寫技術文章,多次受邀在國際會議上做技術講座。

馬裏奧•富斯科(Mario Fusco)

Red Hat高級軟件工程師,負責JBoss規則引擎Drools的核心開發。擁有豐富的Java開發經驗,曾領導媒體公司、金融部門等多個行業的企業級項目開發。對函數式編程和領域特定語言等有濃厚興趣,並創建瞭開放源碼庫lambdaj。

艾倫•米剋羅夫特(Alan Mycroft)

劍橋大學計算機實驗室計算學教授,劍橋大學羅賓遜學院研究員,歐洲編程語言和係統協會聯閤創始人,樹莓派基金會聯閤創始人和理事。發錶過大約100篇研究論文,指導過20多篇博士論文。他的研究主要關注編程語言及其語義、優化和實施。他與業界聯係緊密,曾於學術休假期間在AT&T實驗室和英特爾工作,還創立瞭Codemist公司,該公司設計瞭最初的ARM C編譯器Norcroft。

譯者簡介:

陸明剛

畢業於四川大學,目前在Dell EMC中國卓越研發集團任高級主管工程師,曾任趨勢科技中國軟件研發中心技術經理,在信息科學和工程領域有十餘年的實踐和研究經驗,擁有多項中國及美國專利。關注JVM性能調優和大數據及其實踐,喜歡挖掘技術背後的內幕並樂此不疲。

勞佳

上海交通大學碩士,現任SAP(美國)高級軟件支持顧問。業餘愛好語言、數學、設計,英、法雙語譯者,近年翻譯齣版瞭《谘詢的奧秘》《卓越程序員密碼》《計算進化史:改變數學的命運》等書。

圖書目錄

第一部分 基礎知識
第1章 Java 8、9、10以及11的變化  2
1.1 為什麼要關心Java的變化  2
1.2 Java怎麼還在變  4
1.2.1 Java在編程語言生態係統中的位置  5
1.2.2 流處理  6
1.2.3 用行為參數化把代碼傳遞給方法  7
1.2.4 並行與共享的可變數據  8
1.2.5 Java需要演變  9
1.3 Java中的函數  9
1.3.1 方法和Lambda作為一等值  10
1.3.2 傳遞代碼:一個例子  11
1.3.3 從傳遞方法到Lambda  13
1.4 流  14
1.5 默認方法及Java模塊  17
1.6 來自函數式編程的其他好思想  19
1.7 小結  20
第2章 通過行為參數化傳遞代碼  22
2.1 應對不斷變化的需求  23
2.1.1 初試牛刀:篩選綠蘋果  23
2.1.2 再展身手:把顔色作為參數  23
2.1.3 第三次嘗試:對你能想到的每個屬性做篩選  24
2.2 行為參數化  25
2.3 對付囉唆  30
2.3.1 匿名類  30
2.3.2 第五次嘗試:使用匿名類  31
2.3.3 第六次嘗試:使用Lambda錶達式  32
2.3.4 第七次嘗試:將List類型抽象化  33
2.4 真實的例子  33
2.4.1 用Comparator來排序  33
2.4.2 用Runnable執行代碼塊  34
2.4.3 通過Callable返迴結果  35
2.4.4 GUI事件處理  35
2.5 小結  36
第3章 Lambda錶達式  37
3.1 Lambda管中窺豹  37
3.2 在哪裏以及如何使用Lambda  40
3.2.1 函數式接口  40
3.2.2 函數描述符  42
3.3 把Lambda付諸實踐:環繞執行模式  44
3.3.1 第1 步:記得行為參數化  44
3.3.2 第2 步:使用函數式接口來傳遞行為  45
3.3.3 第3 步:執行一個行為  45
3.3.4 第4 步:傳遞Lambda  46
3.4 使用函數式接口  47
3.4.1 Predicate  47
3.4.2 Consumer  47
3.4.3 Function  48
3.5 類型檢查、類型推斷以及限製  52
3.5.1 類型檢查  52
3.5.2 同樣的Lambda,不同的函數式接口  53
3.5.3 類型推斷  55
3.5.4 使用局部變量  56
3.6 方法引用  57
3.6.1 管中窺豹  57
3.6.2 構造函數引用  60
3.7 Lambda和方法引用實戰  62
3.7.1 第1 步:傳遞代碼  62
3.7.2 第2 步:使用匿名類  62
3.7.3 第3 步:使用Lambda錶達式  62
3.7.4 第4 步:使用方法引用  63
3.8 復閤Lambda錶達式的有用方法  63
3.8.1 比較器復閤  64
3.8.2 謂詞復閤  64
3.8.3 函數復閤  65
3.9 數學中的類似思想  66
3.9.1 積分  66
3.9.2 與Java  8的Lambda聯係起來  68
3.10 小結  68
第二部分 使用流進行函數式數據處理
第4章 引入流  72
4.1 流是什麼  72
4.2 流簡介  76
4.3 流與集閤  78
4.3.1 隻能遍曆一次  79
4.3.2 外部迭代與內部迭代  80
4.4 流操作  82
4.4.1 中間操作  83
4.4.2 終端操作  84
4.4.3 使用流  84
4.5 路綫圖  85
4.6 小結  85
第5章 使用流  86
5.1 篩選  87
5.1.1 用謂詞篩選  87
5.1.2 篩選各異的元素  87
5.2 流的切片  88
5.2.1 使用謂詞對流進行切片  88
5.2.2 截短流  90
5.2.3 跳過元素  90
5.3 映射  91
5.3.1 對流中每一個元素應用函數  91
5.3.2 流的扁平化  92
5.4 查找和匹配  95
5.4.1 檢查謂詞是否至少匹配一個元素  95
5.4.2 檢查謂詞是否匹配所有元素  96
5.4.3 查找元素  96
5.4.4 查找第一個元素  97
5.5 歸約  98
5.5.1 元素求和  98
5.5.2 最大值和最小值  100
5.6 付諸實踐  103
5.6.1 領域:交易員和交易  103
5.6.2 解答  104
5.7 數值流  106
5.7.1 原始類型流特化  107
5.7.2 數值範圍  108
5.7.3 數值流應用:勾股數  108
5.8 構建流  111
5.8.1 由值創建流  111
5.8.2 由可空對象創建流  111
5.8.3 由數組創建流  112
5.8.4 由文件生成流  112
5.8.5 由函數生成流:創建無限流  113
5.9 概述  116
5.10 小結  116
第6章 用流收集數據  118
6.1 收集器簡介  119
6.1.1 收集器用作高級歸約  119
6.1.2 預定義收集器  120
6.2 歸約和匯總  121
6.2.1 查找流中的最大值和最小值  121
6.2.2 匯總  122
6.2.3 連接字符串  123
6.2.4 廣義的歸約匯總  124
6.3 分組  127
6.3.1 操作分組的元素  128
6.3.2 多級分組  130
6.3.3 按子組收集數據  131
6.4 分區  134
6.4.1 分區的優勢  135
6.4.2 將數字按質數和非質數分區  136
6.5 收集器接口  138
6.5.1 理解Collector接口聲明的方法  139
6.5.2 全部融閤到一起  143
6.6 開發你自己的收集器以獲得更好的性能  144
6.6.1 僅用質數做除數  145
6.6.2 比較收集器的性能  148
6.7 小結  150
第7章 並行數據處理與性能  151
7.1 並行流  152
7.1.1 將順序流轉換為並行流  52
7.1.2 測量流性能  154
7.1.3 正確使用並行流  158
7.1.4 高效使用並行流  159
7.2 分支/閤並框架  161
7.2.1 使用RecursiveTask  161
7.2.2 使用分支/閤並框架的最佳做法  164
7.2.3 工作竊取  165
7.3 Spliterator  166
7.3.1 拆分過程  167
7.3.2 實現你自己的Spliterator  168
7.4 小結  173
第三部分 使用流和Lambda進行高效編程
第8章 Collection API的增強功能  176
8.1 集閤工廠  176
8.1.1 List工廠  177
8.1.2 Set工廠  178
8.1.3 Map工廠  179
8.2 使用List和Set  180
8.2.1 removeIf方法  180
8.2.2 replaceAll方法  181
8.3 使用Map  181
8.3.1 forEach方法  182
8.3.2 排序  182
8.3.3 getOrDefault方法  183
8.3.4 計算模式  183
8.3.5 刪除模式  184
8.3.6 替換模式  185
8.3.7 merge方法  185
8.4 改進的ConcurrentHashMap  187
8.4.1 歸約和搜索  187
8.4.2 計數  188
8.4.3 Set視圖  188
8.5 小結  188
第9章 重構、測試和調試  189
9.1 為改善可讀性和靈活性重構代碼  189
9.1.1 改善代碼的可讀性  190
9.1.2 從匿名類到Lambda錶達式的轉換  190
9.1.3 從Lambda錶達式到方法引用的轉換  191
9.1.4 從命令式的數據處理切換到Stream  193
9.1.5 增加代碼的靈活性  193
9.2 使用Lambda重構麵嚮對象的設計模式  195
9.2.1 策略模式  196
9.2.2 模闆方法  197
9.2.3 觀察者模式  198
9.2.4 責任鏈模式  201
9.2.5 工廠模式  202
9.3 測試Lambda錶達式  204
9.3.1 測試可見Lambda函數的行為  204
9.3.2 測試使用Lambda的方法的行為  205
9.3.3 將復雜的Lambda錶達式分為不同的方法  205
9.3.4 高階函數的測試  206
9.4 調試  206
9.4.1 查看棧跟蹤  206
9.4.2 使用日誌調試  208
9.5 小結  209
第10章 基於Lambda的領域特定語言  210
10.1 領域特定語言  212
10.1.1 DSL的優點和弊端  212
10.1.2 JVM中已提供的DSL解決方案  214
10.2 現代Java API中的小型DSL  217
10.2.1 把Stream API當成DSL去操作集閤  219
10.2.2 將Collectors作為DSL匯總數據  220
10.3 使用Java創建DSL的模式與技巧  221
10.3.1 方法鏈接  224
10.3.2 使用嵌套函數  226
10.3.3 使用Lambda錶達式的函數序列  228
10.3.4 把它們都放到一起  230
10.3.5 在DSL中使用方法引用  232
10.4 Java  8 DSL的實際應用  234
10.4.1 jOOQ  235
10.4.2 Cucumber  236
10.4.3 Spring Integration  238
10.5 小結  239
第四部分 無所不在的Java
第11章 用Optional取代null  242
11.1 如何為缺失的值建模  243
11.1.1 采用防禦式檢查減少NullPointerException  243
11.1.2 null帶來的種種問題  245
11.1.3 其他語言中null的替代品  245
11.2 Optional類入門  246
11.3 應用Optional的幾種模式  248
11.3.1 創建Optional對象  248
11.3.2 使用map從Optional對象中提取和轉換值  248
11.3.3 使用flatMap鏈接Optional對象  249
11.3.4 操縱由Optional對象構成的Stream  253
11.3.5 默認行為及解引用Optional對象  254
11.3.6 兩個Optional對象的組閤  255
11.3.7 使用filter剔除特定的值  257
11.4 使用Optional的實戰示例  258
11.4.1 用Optional 封裝可能為null的值  259
11.4.2 異常與Optional的對比  259
11.4.3 基礎類型的Optional對象,以及為什麼應該避免使用它們  260
11.4.4 把所有內容整閤起來  260
11.5 小結  262
第12章 新的日期和時間API  263
12.1 LocalDate、LocalTime、LocalDateTime、Instant、Duration以及Period  264
12.1.1 使用LocalDate和LocalTime  264
12.1.2 閤並日期和時間  265
12.1.3 機器的日期和時間格式  266
12.1.4 定義Duration或Period  267
12.2 操縱、解析和格式化日期  268
12.2.1 使用TemporalAdjuster  270
12.2.2 打印輸齣及解析日期–時間對象  272
12.3 處理不同的時區和曆法  274
12.3.1 使用時區  274
12.3.2 利用和UTC/格林尼治時間的固定偏差計算時區  275
12.3.3 使用彆的日曆係統  276
12.4 小結  277
第13章 默認方法  278
13.1 不斷演進的API  280
13.1.1 初始版本的API  281
13.1.2 第二版API  281
13.2 概述默認方法  283
13.3 默認方法的使用模式  285
13.3.1 可選方法  285
13.3.2 行為的多繼承  286
13.4 解決衝突的規則  289
13.4.1 解決問題的三條規則  289
13.4.2 選擇提供瞭最具體實現的默認方法的接口  290
13.4.3 衝突及如何顯式地消除歧義  291
13.4.4 菱形繼承問題  293
13.5 小結  294
第14章 Java模塊係統  295
14.1 模塊化的驅動力:軟件的推理  295
14.1.1 關注點分離  295
14.1.2 信息隱藏  296
14.1.3 Java軟件  296
14.2 為什麼要設計Java模塊係統  297
14.2.1 模塊化的局限性  297
14.2.2 單體型的JDK  298
14.2.3 與OSGi的比較  299
14.3 Java模塊:全局視圖  300
14.4 使用Java模塊係統開發應用  301
14.4.1 從頭開始搭建一個應用  302
14.4.2 細粒度和粗粒度的模塊化  303
14.4.3 Java模塊係統基礎  303
14.5 使用多個模塊  304
14.5.1 exports子句  304
14.5.2 requires子句  305
14.5.3 命名  306
14.6 編譯及打包  306
14.7 自動模塊  310
14.8 模塊聲明及子句  311
14.8.1 requires  311
14.8.2 exports  311
14.8.3 requires的傳遞  311
14.8.4 exports to  312
14.8.5 open和opens  312
14.8.6 uses和provides  313
14.9 通過一個更復雜的例子瞭解更多  313
14.10 小結  314
第五部分 提升Java的並發性
第15章 CompletableFuture及反應式編程背後的概念  316
15.1 為支持並發而不斷演進的Java  318
15.1.1 綫程以及更高層的抽象  319
15.1.2 執行器和綫程池  320
15.1.3 其他的綫程抽象:非嵌套方法調用  322
15.1.4 你希望綫程為你帶來什麼  324
15.2 同步及異步API  324
15.2.1 Future風格的API  326
15.2.2 反應式風格的API  327
15.2.3 有害的睡眠及其他阻塞式操作  328
15.2.4 實戰驗證  329
15.2.5 如何使用異步API進行異常處理  330
15.3 “綫框–管道”模型  331
15.4 為並發而生的CompletableFuture和結閤器  332
15.5 “發布–訂閱”以及反應式編程  335
15.5.1 示例:對兩個流求和  337
15.5.2 背壓  341
15.5.3 一種簡單的真實背壓  341
15.6 反應式係統和反應式編程  342
15.7 路綫圖  342
15.8 小結  343
第16章 CompletableFuture:組閤式異步編程  344
16.1 Future接口  344
16.1.1 Future接口的局限性  346
16.1.2 使用CompletableFuture構建異步應用  346
16.2 實現異步API  347
16.2.1 將同步方法轉換為異步方法  348
16.2.2 錯誤處理  350
16.3 讓你的代碼免受阻塞之苦  352
16.3.1 使用並行流對請求進行並行操作  353
16.3.2 使用CompletableFuture發起異步請求  353
16.3.3 尋找更好的方案  355
16.3.4 使用定製的執行器  356
16.4 對多個異步任務進行流水綫操作  358
16.4.1 實現摺扣服務  358
16.4.2 使用Discount服務  359
16.4.3 構造同步和異步操作  360
16.4.4 將兩個CompletableFuture對象整閤起來,無論它們是否存在依賴  363
16.4.5 對Future和Completable-Future 的迴顧  364
16.4.6 高效地使用超時機製  365
16.5 響應CompletableFuture的completion事件  366
16.5.1 對最佳價格查詢器應用的優化  367
16.5.2 付諸實踐  368
16.6 路綫圖  369
16.7 小結  369
第17章 反應式編程  370
17.1 反應式宣言  371
17.1.1 應用層的反應式編程  371
17.1.2 反應式係統  373
17.2 反應式流以及Flow API  373
17.2.1 Flow類  374
17.2.2 創建你的第一個反應式應用  377
17.2.3 使用Processor轉換數據  381
17.2.4 為什麼Java並未提供Flow API的實現  383
17.3 使用反應式庫RxJava  384
17.3.1 創建和使用Observable  385
17.3.2 轉換及整閤多個Observable  392
第六部分 函數式編程以及Java未來的演進
第18章 函數式的思考  396
18.1 實現和維護係統  396
18.1.1 共享的可變數據  397
18.1.2 聲明式編程  398
18.1.3 為什麼要采用函數式編程  399
18.2 什麼是函數式編程  399
18.2.1 函數式Java編程  400
18.2.2 引用透明性  402
18.2.3 麵嚮對象的編程和函數式編程的對比  402
18.2.4 函數式編程實戰  403
18.3 遞歸和迭代  405
18.4 小結  408
第19章 函數式編程的技巧  409
19.1 無處不在的函數  409
19.1.1 高階函數  410
19.1.2 柯裏化  411
19.2 持久化數據結構  412
19.2.1 破壞式更新和函數式更新的比較  413
19.2.2 另一個使用Tree的例子  415
19.2.3 采用函數式的方法  416
19.3 Stream的延遲計算  418
19.3.1 自定義的Stream  418
19.3.2 創建你自己的延遲列錶  420
19.4 模式匹配  425
19.4.1 訪問者模式  425
19.4.2 用模式匹配力挽狂瀾  426
19.5 雜項  429
19.5.1 緩存或記憶錶  429
19.5.2 “返迴同樣的對象”意味著什麼  430
19.5.3 結閤器  431
19.6 小結  432
第20章 麵嚮對象和函數式編程的混閤:Java和Scala的比較  433
20.1 Scala簡介  434
20.1.1 你好,啤酒  434
20.1.2 基礎數據結構:List、Set、Map、Tuple、Stream以及Option  436
20.2 函數  440
20.2.1 Scala中的一等函數  441
20.2.2 匿名函數和閉包  442
20.2.3 柯裏化  443
20.3 類和trait  444
20.3.1 更加簡潔的Scala類  445
20.3.2 Scala的trait與Java  8的接口對比  446
20.4 小結  447
第21章 結論以及Java的未來  448
21.1 迴顧Java 8的語言特性  448
21.1.1 行為參數化(Lambda以及方法引用)  449
21.1.2 流  449
21.1.3 CompletableFuture  450
21.1.4 Optional  450
21.1.5 Flow API  451
21.1.6 默認方法  451
21.2 Java  9的模塊係統  451
21.3 Java  10的局部變量類型推斷  453
21.4 Java的未來  454
21.4.1 聲明處型變  454
21.4.2 模式匹配  454
21.4.3 更加豐富的泛型形式  455
21.4.4 對不變性的更深層支持  457
21.4.5 值類型  458
21.5 讓Java發展得更快  461
21.6 寫在最後的話  462
附錄A 其他語言特性的更新  463
附錄B 其他類庫的更新  467
附錄C 如何以並發方式在同一個流上執行多種操作  475
附錄D Lambda錶達式和JVM字節碼  483
· · · · · · (收起)

讀後感

評分

这点东西根本不值当写成一本书。 几篇连续的博客足以完成这个任务,这个任务适合写成几篇连续的博客。 一本书的内容应该比这个多比这个深。比这个多比这个深的内容才适合写成一本书。 一定要多写文字凑够评论字数要求,为了凑够评论字数要求多写了这些无用的话。 其实我想说的...

評分

如果一开始学习Java是从Java 8以下的版本学习的,这本Java 8实战值得一读,Java 8相对于Java 7及之前的版本代码优雅太多,结合现在web业务前后端分离的Spring Boot后端框架,通过Java 8可以写出精炼、优雅的代码。 本书全面的介绍了Java 8的各种写法,第一部分、第二部分属于必...  

評分

評分

这本书作为学习Java8中新增加的编程知识还是非常不错的。在前面章节中,主要介绍了Java8中提供的新特性,比如lamda表达式、stream、函数式编程、CompletableFuture类,新的日期类等等。几乎覆盖了所有的新特性,同时对于原理也有深入的介绍。 在介绍这些Java8中的新特性时,作...  

評分

我是先读的[《Java 8函数式编程》]再读该书,总体是两本书的质量都非常高,五星推荐! 1.相比于《Java 8函数式编程》注重于介绍函数式编程相关,该本覆盖的Java 8特性更全面,在书中能看到对Optional、CompletableFuture、新的日期API的介绍; 2.该书对Stream的收集器介绍得更...  

用戶評價

评分

主要還是JAVA8的內容,加瞭一些java9的一些case。對於響應式編程有個大緻瞭解。

评分

第二版比第一版的內容豐富瞭很多,也深入瞭很多,特彆是後麵對Stream,Completable Future和響應式編程RxJava的講解解答瞭睏惑我很久的問題。

评分

第二版比第一版的內容豐富瞭很多,也深入瞭很多,特彆是後麵對Stream,Completable Future和響應式編程RxJava的講解解答瞭睏惑我很久的問題。

评分

如果未讀過第一版,那麼這邊書力薦閱讀,如果讀過第一版,這本書推薦閱讀

评分

主要還是JAVA8的內容,加瞭一些java9的一些case。對於響應式編程有個大緻瞭解。

本站所有內容均為互聯網搜索引擎提供的公開搜索信息,本站不存儲任何數據與內容,任何內容與數據均與本站無關,如有需要請聯繫相關搜索引擎包括但不限於百度google,bing,sogou

© 2025 book.quotespace.org All Rights Reserved. 小美書屋 版权所有