Java異步編程實戰

Java異步編程實戰 下載 mobi epub pdf 電子書 2025

翟陸續
圖書標籤:
想要找書就要到 圖書大百科
立刻按 ctrl+D收藏本頁
你會得到大驚喜!!
前言
第1章 認識異步編程1
1.1 異步編程概念與作用1
1.2 異步編程場景2
1.3 總結9
第2章 顯式使用綫程和綫程池實現異步編程10
2.1 顯式使用綫程實現異步編程10
2.2 顯式使用綫程池實現異步編程14
2.2.1 如何顯式使用綫程池實現異步編程14
2.2.2 綫程池ThreadPoolExecutor原理剖析17
2.3 總結34
第3章 基於JDK中的Future實現異步編程35
3.1 JDK 中的Future35
3.2 JDK中的FutureTask37
3.2.1 FutureTask 概述37
3.2.2 FutureTask的類圖結構41
3.2.3 FutureTask的run() 方法45
3.2.4 FutureTask的get()方法48
3.2.5 FutureTask的cancel(boolean mayInterruptIfRunning)方法50
3.2.6 FutureTask的局限性52
3.3 JDK中的CompletableFuture52
3.3.1 CompletableFuture 概述52
3.3.2 顯式設置CompletableFuture結果54
3.3.3 基於CompletableFuture實現異步計算與結果轉換56
3.3.4 多個CompletableFuture進行組閤運算65
3.3.5 異常處理68
3.3.6 CompletableFuture概要原理70
3.4 JDK8 Stream & CompletableFuture76
3.4.1 JDK8 Stream76
3.4.2 當Stream遇見CompletableFuture79
3.5 總結81
第4章 Spring框架中的異步執行82
4.1 Spring中對TaskExecutor的抽象82
4.2 如何在Spring中使用異步執行84
4.2.1 使用TaskExecutor實現異步執行84
4.2.2 使用注解@Async實現異步執行89
4.3 @Async注解異步執行原理96
4.4 總結109
第5章 基於反應式編程實現異步編程110
5.1 反應式編程概述110
5.2 Reactive Streams規範120
5.3 基於RxJava實現異步編程123
5.4 基於Reactor實現異步編程133
5.5 總結136
第6章 Web Servlet的異步非阻塞處理137
6.1 Servlet概述137
6.2 Servlet 3.0 提供的異步處理能力138
6.3 Servlet 3.1 提供的非阻塞IO能力145
6.4 Spring Web MVC 的異步處理能力153
6.4.1 基於DeferredResult的異步處理154
6.4.2 基於Callable實現異步處理155
6.5 總結157
第7章 Spring WebFlux的異步非阻塞處理158
7.1 Spring WebFlux概述158
7.2 Reactive編程 & Reactor庫159
7.3 WebFlux服務器160
7.4 WebFlux的並發模型163
7.5 WebFlux對性能的影響164
7.6 WebFlux的編程模型164
7.6.1 WebFlux注解式編程模型165
7.6.2 WebFlux函數式編程模型168
7.7 WebFlux原理淺嘗171
7.7.1 Reactor Netty概述171
7.7.2 WebFlux服務器啓動流程173
7.7.3 WebFlux一次服務調用流程182
7.8 WebFlux的適用場景185
7.9 總結186
第8章 高性能異步編程框架和中間件187
8.1 異步、基於事件驅動的網絡編程框架—Netty187
8.1.1 Netty概述187
8.1.2 Netty的綫程模型190
8.1.3 TCP半包與粘包問題196
8.1.4 基於Netty與CompletableFuture實現RPC異步調用198
8.2 高性能RPC框架—Apache Dubbo209
8.2.1 Apache Dubbo概述209
8.2.2 Dubbo的異步調用210
8.2.3 Dubbo的異步執行214
8.3 高性能綫程間消息傳遞庫—Disruptor217
8.3.1 Disruptor概述217
8.3.2 Disruptor的特性詳解220
8.3.3 基於Disruptor實現異步編程223
8.4 異步、分布式、基於消息驅動的框架—Akka227
8.4.1 Akka概述227
8.4.2 傳統編程模型存在的問題228
8.4.3 Actor模型解決瞭傳統編程模型的問題232
8.4.4 基於Akka實現異步編程237
8.5 高性能分布式消息框架—Apache RocketMQ244
8.5.1 Apache RocketMQ概述244
8.5.2 基於Apache RocketMQ實現係統間異步解耦246
8.6 總結254
第9章 Go語言的異步編程能力255
9.1 Go語言概述255
9.2 Go語言的綫程模型256
9.2.1 一對一模型256
9.2.2 多對一模型257
9.2.3 多對多模型258
9.2.4 Go語言的綫程模型259
9.3 goroutine與channel261
9.3.1 goroutine261
9.3.2 channel265
9.3.3 構建管道實現異步編程269
9.4 總結273
· · · · · · (收起)

具體描述

內容簡介

這是一部全麵解析Java異步編程的著作,針對各種常見異步編程場景,從編程語言、開發框架等角度深入講解瞭異步編程的原理和方法。作者是淘寶的資深Java技術工程師,在Java異步編程、並發編程領域有深厚的積纍。

全書共9章,每章內容概括如下:

第1-2章主要介紹瞭異步編程的概念、適用場景,以及如何使用綫程和綫程池來實現異步編程;

第3章首先講解JDK中的各種Future及其內部實現原理,然後講解如何使用Future實現異步編程,以及如何結閤JDK8 Stream 和Future實現異步編程;

第4章講解瞭Spring框架中提供的異步執行能力,包含Spring中如何對TaskExecutor進行抽象,如何使用注解@Async實現異步編程,以及其內部實現原理;

第5章講解瞭比較熱門的反應式編程相關的內容,包含什麼是反應式編程,如何使用反應式編程規範的庫RxJava和Reactor庫實現異步編程;

第6章講解瞭Web Servlet的異步非阻塞處理,包含Servlet 3.0規範是如何提供異步處理能力的,Servlet 3.1規範是如何解決IO阻塞問題的,以及在Spring MVC中如何進行異步處理。

第7章講解與Servlet技術棧並行存在的、由Spring5.0提齣來的Spring WebFlux的異步非阻塞處理,包含Spring WebFlux的由來、Spring WebFlux的並發模型、兩種編程模型,以及如何使用Spring WebFlux來進行服務開發、Spring WebFlux內部的實現原理。

第8章簡要介紹瞭業界為方便實現異步編程而設計的一些框架和中間件,比如異步基於事件驅動的網絡編程框架Netty,高性能RPC框架Apache Dubbo,高性能綫程間消息傳遞庫Disruptor,異步基、分布式、基於事件驅動的編程框架Akka,高性能分布式消息平颱Apache RocketMQ 。

第9章介紹新興的Go語言是如何從語言層麵提供瞭強大的異步編程能力的。

本書注重理論與實踐相結閤,且每個異步技術點都附有代碼實例,幫助讀者加深理解。

用戶評價

評分

##深入淺齣

評分

##封麵Java這個杯子太經典瞭,正好最近用到並發編程,作為學習指南還不錯。

評分

##泛泛而談,開捲有益

評分

前麵說綫程的一章還不錯,後麵就比較普通瞭,因為這麼薄也不可能把異步編程講的太細緻,reactor,webflux也隻是匆匆帶過。

評分

##歸納總結Java的異步編程

評分

##代碼排版太亂,到最後還講到Goroutine去瞭,對於這書名講go語言協程,這跑題跑的真夠遠的。估計這是因為作者的意願,更願意換go語言寫高並發程序,但是完全忽視瞭客觀性——go和java在實際應用中性能根本相差不瞭多少(各種測試都錶明各有韆鞦)。而這本書的主題應該是JVM的並發環境,講kotlin也比講go閤適吧?

評分

##代碼排版太亂,到最後還講到Goroutine去瞭,對於這書名講go語言協程,這跑題跑的真夠遠的。估計這是因為作者的意願,更願意換go語言寫高並發程序,但是完全忽視瞭客觀性——go和java在實際應用中性能根本相差不瞭多少(各種測試都錶明各有韆鞦)。而這本書的主題應該是JVM的並發環境,講kotlin也比講go閤適吧?

評分

##封麵Java這個杯子太經典瞭,正好最近用到並發編程,作為學習指南還不錯。

評分

##異步一直不太明白,希望通過這本書能搞清楚一些重要的概念與思想

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

© 2025 book.teaonline.club All Rights Reserved. 圖書大百科 版權所有