国内首部Java多线程设计模式原创作品《Java多线程编程实战指南(设计模式篇)》已由电子工业出版社出版。本书从理论到实战,用生活化的实例和通俗易懂的语言全面介绍Java多线程编程的"三十六计"——多线程设计模式。
当当、亚马逊、京东、互动出版网、淘宝等各大书店有售。
第1章 Java多线程编程实战基础 1
1.1 无处不在的线程 1
1.2 线程的创建与运行 2
1.3 线程的状态与上下文切换 5
1.4 线程的监视 7
1.5 原子性、内存可见性和重排序——重新认识synchronized和volatile 10
1.6 线程的优势和风险 11
1.7 多线程编程常用术语 13
第2章 设计模式简介 17
2.1 设计模式及其作用 17
2.2 多线程设计模式简介 20
2.3 设计模式的描述 21
第3章 Immutable Object(不可变对象)模式 23
3.1 Immutable Object模式简介 23
3.2 Immutable Object模式的架构 25
3.3 Immutable Object模式实战案例 27
3.4 Immutable Object模式的评价与实现考量 31
3.5 Immutable Object模式的可复用实现代码 32
3.6 Java标准库实例 32
3.7 相关模式 34
3.7.1 Thread Specific Storage模式(第10章) 34
3.7.2 Serial Thread Confinement模式(第11章) 34
3.8 参考资源 34
第4章 Guarded Suspension(保护性暂挂)模式 35
4.1 Guarded Suspension模式简介 35
4.2 Guarded Suspension模式的架构 35
4.3 Guarded Suspension模式实战案例解析 39
4.4 Guarded Suspension模式的评价与实现考量 45
4.4.1 内存可见性和锁泄漏(Lock Leak) 46
4.4.2 线程过早被唤醒 46
4.4.3 嵌套监视器锁死 47
4.5 Guarded Suspension模式的可复用实现代码 50
4.6 Java标准库实例 50
4.7 相关模式 51
4.7.1 Promise模式(第6章) 51
4.7.2 Producer-Consumer模式(第7章) 51
4.8 参考资源 51
第5章 Two-phase Termination(两阶段终止)模式 52
5.1 Two-phase Termination模式简介 52
5.2 Two-phase Termination模式的架构 53
5.3 Two-phase Termination模式实战案例 56
5.4 Two-phase Termination模式的评价与实现考量 63
5.4.1 线程停止标志 63
5.4.2 生产者-消费者问题中的线程停止 64
5.4.3 隐藏而非暴露可停止的线程 65
5.5 Two-phase Termination模式的可复用实现代码 65
5.6 Java标准库实例 66
5.7 相关模式 66
5.7.1 Producer-Consumer模式(第7章) 66
5.7.2 Master-Slave模式(第12章) 66
5.8 参考资源 66
第6章 Promise(承诺)模式 67
6.1 Promise模式简介 67
6.2 Promise模式的架构 68
6.3 Promise模式实战案例解析 70
6.4 Promise模式的评价与实现考量 74
6.4.1 异步方法的异常处理 75
6.4.2 轮询(Polling) 75
6.4.3 异步任务的执行 75
6.5 Promise模式的可复用实现代码 77
6.6 Java标准库实例 77
6.7 相关模式 78
6.7.1 Guarded Suspension模式(第4章) 78
6.7.2 Active Object模式(第8章) 78
6.7.3 Master-Slave模式(第12章) 78
6.7.4 Factory Method模式 78
6.8 参考资源 79
第7章 Producer-Consumer(生产者/消费者)模式 80
7.1 Producer-Consumer模式简介 80
7.2 Producer-Consumer模式的架构 80
7.3 Producer-Consumer模式实战案例解析 83
7.4 Producer-Consumer模式的评价与实现考量 87
7.4.1 通道积压 87
7.4.2 工作窃取算法 88
7.4.3 线程的停止 92
7.4.4 高性能高可靠性的Producer-Consumer模式实现 92
7.5 Producer-Consumer模式的可复用实现代码 92
7.6 Java标准库实例 93
7.7 相关模式 93
7.7.1 Guarded Suspension模式(第4章) 93
7.7.2 Thread Pool模式(第9章) 93
7.8 参考资源 93
第8章 Active Object(主动对象)模式 94
8.1 Active Object模式简介 94
8.2 Active Object模式的架构 95
8.3 Active Object模式实战案例解析 98
8.4 Active Object模式的评价与实现考量 105
8.4.1 错误隔离 107
8.4.2 缓冲区监控 108
8.4.3 缓冲区饱和处理策略 108
8.4.4 Scheduler空闲工作者线程清理 109
8.5 Active Object模式的可复用实现代码 109
8.6 Java标准库实例 111
8.7 相关模式 112
8.7.1 Promise模式(第6章) 112
8.7.2 Producer-Consumer模式(第7章) 112
8.8 参考资源 112
第9章 Thread Pool(线程池)模式 113
9.1 Thread Pool模式简介 113
9.2 Thread Pool模式的架构 114
9.3 Thread Pool模式实战案例解析 116
9.4 Thread Pool模式的评价与实现考量 117
9.4.1 工作队列的选择 118
9.4.2 线程池大小调校 119
9.4.3 线程池监控 121
9.4.4 线程泄漏 122
9.4.5 可靠性与线程池饱和处理策略 122
9.4.6 死锁 125
9.4.7 线程池空闲线程清理 126
9.5 Thread Pool模式的可复用实现代码 127
9.6 Java标准库实例 127
9.7 相关模式 127
9.7.1 Two-phase Termination模式(第5章) 127
9.7.2 Promise模式(第6章) 127
9.7.3 Producer-Consumer模式(第7章) 127
9.8 参考资源 128
第10章 Thread Specific Storage(线程特有存储)模式 129
10.1 Thread Specific Storage模式简介 129
10.2 Thread Specific Storage模式的架构 131
10.3 Thread Specific Storage模式实战案例解析 133
10.4 Thread Specific Storage模式的评价与实现考量 135
10.4.1 线程池环境下使用Thread Specific Storage模式 138
10.4.2 内存泄漏与伪内存泄漏 139
10.5 Thread Specific Storage模式的可复用实现代码 145
10.6 Java标准库实例 146
10.7 相关模式 146
10.7.1 Immutable Object模式(第3章) 146
10.7.2 Proxy(代理)模式 146
10.7.3 Singleton(单例)模式 146
10.8 参考资源 147
第11章 Serial Thread Confinement(串行线程封闭)模式 148
11.1 Serial Thread Confinement模式简介 148
11.2 Serial Thread Confinement模式的架构 148
11.3 Serial Thread Confinement模式实战案例解析 151
11.4 Serial Thread Confinement模式的评价与实现考量 155
11.4.1 任务的处理结果 155
11.5 Serial Thread Confinement模式的可复用实现代码 156
11.6 Java标准库实例 160
11.7 相关模式 160
11.7.1 Immutable Object模式(第3章) 160
11.7.2 Promise模式(第6章) 160
11.7.3 Producer-Consumer模式(第7章) 160
11.7.4 Thread Specific Storage(线程特有存储)模式 (第10章) 161
11.8 参考资源 161
第12章 Master-Slave(主仆)模式 162
12.1 Master-Slave模式简介 162
12.2 Master-Slave模式的架构 162
12.3 Master-Slave模式实战案例解析 164
12.4 Master-Slave模式的评价与实现考量 171
12.4.1 子任务的处理结果的收集 172
12.4.2 Slave参与者实例的负载均衡与工作窃取 173
12.4.3 可靠性与异常处理 173
12.4.4 Slave线程的停止 174
12.5 Master-Slave模式的可复用实现代码 174
12.6 Java标准库实例 186
12.7 相关模式 186
12.7.1 Two-phase Termination模式(第5章) 186
12.7.2 Promise模式(第6章) 186
12.7.3 Strategy(策略)模式 186
12.7.4 Template(模板)模式 186
12.7.5 Factory Method(工厂方法)模式 186
12.8 参考资源 187
第13章 Pipeline(流水线)模式 188
13.1 Pipeline模式简介 188
13.2 Pipeline模式的架构 189
13.3 Pipeline模式实战案例解析 194
13.4 Pipeline模式的评价与实现考量 208
13.4.1 Pipeline的深度 209
13.4.2 基于线程池的Pipe 209
13.4.3 错误处理 212
13.4.4 可配置的Pipeline 212
13.5 Pipeline模式的可复用实现代码 212
13.6 Java标准库实例 222
13.7 相关模式 222
13.7.1 Serial Thread Confinement模式(第11章) 222
13.7.2 Master-Slave模式(第12章) 222
13.7.3 Composite模式 223
13.8 参考资源 223
第14章 Half-sync/Half-async(半同步/半异步)模式 224
14.1 Half-sync/Half-async模式简介 224
14.2 Half-sync/Half-async模式的架构 224
14.3 Half-sync/Half-async模式实战案例解析 226
14.4 Half-sync/Half-async模式的评价与实现考量 234
14.4.1 队列积压 235
14.4.2 避免同步层处理过慢 235
14.5 Half-sync/Half-async模式的可复用实现代码 236
14.6 Java标准库实例 240
14.7 相关模式 240
14.7.1 Two-phase Termination模式(第5章) 240
14.7.2 Producer-Consumer模式(第7章) 241
14.7.3 Active Object模式(第8章) 241
14.7.4 Thread Pool模式(第9章) 241
14.8 参考资源 241
第15章 模式语言 242
15.1 模式与模式间的联系 242
15.2 mmutable Object(不可变对象)模式 244
15.3 Guarded Suspension(保护性暂挂)模式 244
15.4 Two-phase Termination(两阶段终止)模式 245
15.5 Promise(承诺)模式 246
15.6 Producer-Consumer(生产者/消费者)模式 247
15.7 Active Object(主动对象)模式 248
15.8 Thread Pool(线程池)模式 249
15.9 Thread Specific Storage(线程特有存储)模式 250
15.10 Serial Thread Confinement(串行线程封闭)模式 251
15.11 Master-Slave(主仆)模式 252
15.12 Pipeline(流水线)模式 253
15.13 Half-sync/Half-async(半同步/半异步)模式 254
附录 本书常用UML图指南 255
A.1 UML简介 255
A.2 类图(Class Diagram) 256
A.1.1 类的属性、方法和立体型(Stereotype) 256
A.1.2 类与类之间的关系 258
A.3 序列图(Sequence Diagram) 261
参考文献 263
相关推荐
Java多线程编程是Java开发中的核心话题,它涉及到线程的创建、同步、通信以及线程池等高级特性。在面试中,面试官常会询问候选人关于线程安全、死锁、活锁等问题,并要求应试者能够编写或分析并发代码。此外,算法...
本篇文档对后端开发中的关键知识点进行了全面而深入的梳理,涵盖了Java语言基础、JVM、操作系统、网络技术、数据库、缓存、多线程、Spring框架等方面的核心概念和技术要点。以下是针对文档标题、描述以及部分内容中...
包括但不限于计算机网络、操作系统、集合框架、JVM内存管理、多线程并发、数据库(如MySQL)、缓存(如Redis)、框架(如Spring)、基础Java知识、系统设计、Linux管理和正则表达式以及设计模式和算法。 在计算机...
36. **设计模式**: - 单例模式:确保一个类只有一个实例。 - 工厂模式:提供创建对象的接口。 - 适配器模式:使不兼容的接口能够协同工作。 - 责任链模式:传递请求直到被处理。 - 观察者模式:对象之间的一对...
这需要对HTTP协议有深入的理解,并熟悉Java(nanohttpd是用Java实现的)的网络编程和多线程编程。 总之,nanohttpd是一个轻量级的HTTP服务器项目,其源码适合初学者研究HTTP协议和服务器实现,同时也适用于专业...
《Qt5开发及实例》这本书作为国内首部基于Qt5的出版物,是初学者进入Qt世界的理想指南。 书中涵盖了Qt5的基础概念,如信号与槽机制,这是Qt设计模式的核心,允许组件间的通信。信号表示对象状态的变化,而槽是响应...
### 设计模式 - **单例模式**:确保一个类只有一个实例,并提供一个全局访问点。 - **工厂模式**:提供创建一系列相关或相互依赖对象的接口,无需指定它们具体的类。 - **观察者模式**:当一个对象的状态发生改变时...
5. **多线程与并发**:在服务端编程中,为了同时处理多个客户端连接,通常会用到多线程或异步IO。C语言提供`pthread`库支持多线程编程,或者可以使用select、poll、epoll等机制实现并发处理。 6. **安全编程**:...
1. Java基础:数据类型、面向对象、集合框架、多线程、异常处理。 2. JVM:内存模型、垃圾回收机制、类加载机制、JVM调优。 3. 设计模式:了解并能灵活运用常见的23种设计模式。 4. Spring框架:IOC、AOP、Spring ...
7. **Java同步方法**:Java中可以使用synchronized关键字实现方法同步,防止多线程环境下数据竞争问题。 8. **Java线程实现**:Java提供了Thread类和Runnable接口两种方式来创建和运行线程。 9. **PHP框架对比**:...
- 设计模式,如工厂模式、单例模式、观察者模式等,体现了良好的代码组织和可维护性。 - 版本控制工具,如Git,以及敏捷开发和持续集成/持续部署(CI/CD)的概念,展示了项目管理能力。 - 测试和调试技巧,包括...
5. 多线程与异步处理:为了处理并发的UDP数据报,服务器通常需要多线程或多进程技术,以便同时处理多个客户端的请求。异步处理则能确保服务器在等待响应时不会阻塞其他操作。 6. 安全性:由于UDP本身不提供加密或...
**设计模式**:面试中提到的单例模式和工厂模式是常用的面向对象设计模式,用于创建对象的控制和管理。 **反向工程**: - **汇编语言**:了解基本的跳转指令(短跳2字节,近跳3字节,远跳5字节)和函数返回指令`ret...
UDP(User Datagram Protocol)通信工程主要涉及网络编程中的无连接通信模式。在这个工程中,我们可能会看到以下几个关键知识点: 1. UDP协议基础:UDP是一种无连接的传输层协议,它不建立连接,也不保证数据的可靠...
如果类设计用于多线程环境,它可能包含了锁或其他同步机制,以确保并发访问时的正确性。 9. **测试与示例**: 为了确保类的正确功能,通常会提供测试用例或示例代码,演示如何创建队列、添加和移除元素、检查队列...
这种设计模式使得代码更加简洁、可读,同时避免了多线程中的竞态条件和死锁问题。 在Reel中,每个连接都被视为一个独立的Celluloid Actor,这样可以确保每个请求都能独立执行,互不干扰。当客户端发送请求时,Reel...
3. **多线程支持**:LwIP可以配置为多线程模式,以适应多核处理器环境,提供更高的并发处理能力。 4. **TCP连接管理**:LwIP实现了TCP的连接建立、数据传输、连接关闭等过程,包括滑动窗口机制、超时重传、拥塞控制...
8.5.2 内核模式下开启多线程 8.5.3 内核模式下的事件对象 8.5.4 驱动程序与应用程序交互事件对象 8.5.5 驱动程序与驱动程序交互事件对象 8.5.6 内核模式下的信号灯 8.5.7 内核模式下的互斥体 ...
8.5.2 内核模式下开启多线程 8.5.3 内核模式下的事件对象 8.5.4 驱动程序与应用程序交互事件对象 8.5.5 驱动程序与驱动程序交互事件对象 8.5.6 内核模式下的信号灯 8.5.7 内核模式下的互斥体 ...
开发者可以使用Java编程语言,基于Android SDK平台来开发大量的增值应用。 #### 15.2 Android平台技术架构 ##### 15.2.1 Android平台技术特性 Android平台具有以下技术特性: - **应用程序框架**:支持组件的...