一、目录介绍

第1章 简介

1.1   并发简史

1.2   线程的优势

1.2.1 发挥多处理器的强大能力

1.2.2 建模的简单性

1.2.3 异步事件的简化处理

1.2.4 响应更灵敏的用户界面

1.3   线程带来的风险

1.3.1 安全性问题

1.3.2 活跃性问题

1.3.3 性能问题

1.4   线程无处不在

第一部分 基础知识

第2章 线程安全性

2.1   什么是线程安全性

2.2   原子性

2.2.1 竞态条件

2.2.2 示例:延迟初始化中的竞态条件

2.2.3 复合操作

2.3   加锁机制

2.3.1 内置锁

2.3.2 重入

2.4   用锁来保护状态

2.5   活跃性与性能

第3章 对象的共享

3.1   可见性

3.1.1 失效数据

3.1.2 非原子的64位操作

3.1.3 加锁与可见性

3.1.4 Volatile变量

3.2   发布与逸出

3.3   线程封闭

3.3.1 Ad-hoc线程封闭

3.3.2 栈封闭

3.3.3 ThreadLocal类

3.4   不变性

3.4.1 Final域

3.4.2 示例:使用Volatile类型来发布不可变对象

3.5   安全发布

3.5.1 不正确的发布:正确的对象被破坏

3.5.2  不可变对象与初始化安全性

3.5.3 安全发布的常用模式

3.5.4 事实不可变对象

3.5.5 可变对象

3.5.6 安全地共享对象

第4章 对象的组合

4.1   设计线程安全的类

4.1.1 收集同步需求

4.1.2 依赖状态的操作

4.1.3 状态的所有权

4.2   实例封闭

4.2.1 Java监视器模式

4.2.2 示例:车辆追踪

4.3   线程安全性的委托

4.3.1 示例:基于委托的车辆追踪器

4.3.2 独立的状态变量

4.3.3 当委托失效时

4.3.4 发布底层的状态变量

4.3.5 示例:发布状态的车辆追踪器

4.4   在现有的线程安全类中添加功能

4.4.1 客户端加锁机制

4.4.2 组合

4.5   将同步策略文档化

第5章 基础构建模块

5.1   同步容器类

5.1.1 同步容器类的问题

5.1.2 迭代器与Concurrent-Modification Exception

5.1.3 隐藏迭代器

5.2   并发容器

5.2.1 Concurrent Hash Map

5.2.2 额外的原子Map操作

5.2.3 Copy On Write Array List

5.3   阻塞队列和生产者-消费者模式

5.3.1 示例:桌面搜索

5.3.2 串行线程封闭

5.3.3 双端队列与工作密取

5.4   阻塞方法与中断方法

5.5   同步工具类

5.5.1 闭锁

5.5.2 Future Task

5.5.3 信号量

5.5.4 栅栏

5.6   构建高效且可伸缩的结果缓存

第二部分 结构化并发应用程序

第6章 任务执行

6.1   在线程中执行任务

6.1.1 串行地执行任务

6.1.2 显式地为任务创建线程

6.1.3 无限制创建线程的不足

6.2   Executor框架

6.2.1 示例:基于Executor的Web服务器

6.2.2 执行策略

6.2.3 线程池

6.2.4 Executor的生命周期

6.2.5 延迟任务与周期任务

6.3   找出可利用的并行性

6.3.1 示例:串行的页面渲染器

6.3.2 携带结果的任务Callable与Future

6.3.3 示例:使用Future实现页面渲染器

6.3.4 在异构任务并行化中存在的局限

6.3.5 Completion Service:Executor与Blocking Queue

6.3.6 示例:使用Completion Service实现页面渲染器

6.3.7 为任务设置时限

6.3.8 示例:旅行预定门户网站

第7章 取消与关闭

7.1   任务取消

7.1.1 中断

7.1.2 中断策略

7.1.3 响应中断

7.1.4 示例:计时运行

7.1.5 通过Future来实现取消

7.1.6 处理不可中断的阻塞

7.1.7 采用New Task For来封装非标准的取消

7.2   停止基于线程的服务

7.2.1 示例:日志服务

7.2.2 关闭Executor Service

7.2.3 “毒丸”对象

7.2.4 示例:只执行一次的服务

7.2.5 Shutdown Now的局限性

7.3   处理非正常的线程终止

7.4   JVM关闭

7.4.1 关闭钩子

7.4.2 守护线程

7.4.3 终结器

第8章 线程池的使用

8.1   在任务与执行策略之间的隐性耦合

8.1.1 线程饥饿死锁

8.1.2 运行时间较长的任务

8.2   设置线程池的大小

8.3   配置Thread Pool Executor

8.3.1 线程的创建与销毁

8.3.2 管理队列任务

8.3.3 饱和策略

8.3.4 线程工厂

8.3.5 在调用构造函数后再定制Thread Pool Executor

8.4   扩展 Thread Pool Executor

8.5   递归算法的并行化

第9章 图形用户界面应用程序

9.1   为什么GUI是单线程的

9.1.1 串行事件处理

9.1.2 Swing中的线程封闭机制

9.2   短时间的GUI任务

9.3   长时间的GUI任务

9.3.1 取消

9.3.2 进度标识和完成标识

9.3.3 Swing Worker

9.4   共享数据模型

9.4.1 线程安全的数据模型

9.4.2 分解数据模型

9.5   其他形式的单线程子系统

第三部分 活跃性、性能与测试

第10章 避免活跃性危险

10.1   死锁

10.1.1 锁顺序死锁

10.1.2 动态的锁顺序死锁

10.1.3 在协作对象之间发生的死锁

10.1.4 开放调用

10.1.5 资源死锁

10.2   死锁的避免与诊断

10.2.1 支持定时的锁

10.2.2 通过线程转储信息来分析死锁

10.3   其他活跃性危险

10.3.1 饥饿

10.3.2 糟糕的响应性

10.3.3 活锁

第11章 性能与可伸缩性

11.1   对性能的思考

11.1.1 性能与可伸缩性

11.1.2 评估各种性能权衡因素

11.2   Amdahl定律

11.2.1 示例:在各种框架中隐藏的串行部分

11.2.2 Amdahl定律的应用

11.3   线程引入的开销

11.3.1 上下文切换

11.3.2 内存同步

11.3.3 阻塞

11.4   减少锁的竞争

11.4.1 缩小锁的范围(“快进快出”)

11.4.2 减小锁的粒度

11.4.3 锁分段

11.4.4 避免热点域

11.4.5 一些替代独占锁的方法

11.4.6 监测CPU的利用率

11.4.7 向对象池说“不”

11.5   示例:比较Map的性能

11.6   减少上下文切换的开销

第12章 并发程序的测试

12.1   正确性测试

12.1.1 基本的单元测试

12.1.2 对阻塞操作的测试

12.1.3 安全性测试

12.1.4 资源管理的测试

12.1.5 使用回调

12.1.6 产生更多的交替操作

12.2   性能测试

12.2.1 在PutTakeTest中增加计时功能

12.2.2 多种算法的比较

12.2.3 响应性衡量

12.3   避免性能测试的陷阱

12.3.1 垃圾回收

12.3.2 动态编译

12.3.3 对代码路径的不真实采样

12.3.4 不真实的竞争程度

12.3.5 无用代码的消除

12.4   其他的测试方法

12.4.1 代码审查

12.4.2 静态分析工具

12.4.3 面向方面的测试技术

12.4.4 分析与监测工具

第四部分 高级主题

第13章 显式锁

13.1   Lock与 Reentrant Lock

13.1.1 轮询锁与定时锁

13.1.2 可中断的锁获取操作

13.1.3 非块结构的加锁

13.2   性能考虑因素

13.3   公平性

13.4   在synchronized和Reentrant Lock之间进行选择

13.5   读-写锁

第14章 构建自定义的同步工具

14.1   状态依赖性的管理

14.1.1 示例:将前提条件的失败传递给调用者

14.1.2 示例:通过轮询与休眠来实现简单的阻塞

14.1.3 条件队列

14.2   使用条件队列

14.2.1 条件谓词

14.2.2 过早唤醒

14.2.3 丢失的信号

14.2.4 通知

14.2.5 示例:阀门类

14.2.6 子类的安全问题

14.2.7 封装条件队列

14.2.8 入口协议与出口协议

14.3   显式的Condition对象

14.4   Synchronizer剖析

14.5   Abstract Queued Synchronizer

14.6   java.util.concurrent同步器类中的 AQS

14.6.1 ReentrantLock

14.6.2 Semaphore与CountDownLatch

14.6.3 FutureTask

14.6.4 ReentrantReadWriteLock

第15章 原子变量与非阻塞同步机制

15.1   锁的劣势

15.2   硬件对并发的支持

15.2.1 比较并交换

15.2.2 非阻塞的计数器

15.2.3 JVM对CAS的支持

15.3   原子变量类

15.3.1 原子变量是一种“更好的volatile”

15.3.2 性能比较:锁与原子变量

15.4   非阻塞算法

15.4.1 非阻塞的栈

15.4.2 非阻塞的链表

15.4.3 原子的域更新器

15.4.4 ABA问题

第16章 Java内存模型

16.1   什么是内存模型,为什么需要它

16.1.1 平台的内存模型

16.1.2 重排序

16.1.3 Java内存模型简介

16.1.4 借助同步

16.2   发布

16.2.1 不安全的发布

16.2.2 安全的发布

16.2.3 安全初始化模式

16.2.4 双重检查加锁

16.3   初始化过程中的安全性

附录A 并发性标注

参考文献��

Java并发编程实战_《Java并发编程实战》PDF版本下载相关推荐

  1. java高并发编程艺术_[高并发]Java高并发编程系列开山篇--线程实现

    Java是最早开始有并发的语言之一,再过去传统多任务的模式下,人们发现很难解决一些更为复杂的问题,这个时候我们就有了并发. 引用 多线程比多任务更加有挑战.多线程是在同一个程序内部并行执行,因此会对相 ...

  2. java最少有多少线程_【并发编程】一个最简单的Java程序有多少线程?

    一个最简单的Java程序有多少线程? 通过下面程序可以计算出当前程序的线程总数. import java.lang.management.ManagementFactory; import java. ...

  3. java 多线程不安全_多线程并发为什么不安全

    一.线程安全定义 ​定义: ​多个线程访问同一个对象时,如果不用考虑这些线程在运行时环境下的调度和交替执行,也不需要进行额外的同步,或者在调用方进行任何其他操作,调用这个对象的行为都可以获得正确的结果 ...

  4. pta中java编程题_多文件编程题

    多文件编程题与函数题相似,区别是裁判编写的判题程序可能涉及多个文件,因此不是写在题干里,而是以附件的形式供学生下载,方便学生调试.学生须按照题干上给出的要求编写程序,完成指定功能.学生的提交也可能包含 ...

  5. 扇贝python编程课_【扇贝编程python安卓手机下载】扇贝编程app v1.1.47 破解版-趣致软件园...

    扇贝编程python是运行于安卓平台的一款专业Python课程学习应用,该应用内置了专业强大的教研团队与交互式学习方法,同时还能够支持电脑.手机进度同步,自动保存学习进度,让用户能够使用扇贝编程轻松精 ...

  6. java教程孙鑫_[Java基础] 孙鑫老师JAVA无难事视频教程 最适合java入门学习打基础的课程 附源码...

    资源介绍 课程介绍 由孙鑫老师亲自授课录制.内容涵盖面广,从入门到精通,授课通俗易懂,分析问题独到精辟,学员通过本套光盘的学习,能够快速掌握Java编程语言,成为Java高手. 由孙鑫老师亲自授课录制 ...

  7. java 字符串格式替换_[Java] - 格式字符串替换方法

    Java 字符串格式替换方法有两种,一种是使用String.format(...),另一种是使用MessageFormat.format(...) 如下: import java.text.Messa ...

  8. java 基础面试 英文_[Java面试] 面试java基础总结大全

    原标题:[Java面试] 面试java基础总结大全 基础知识: 1.JVM.JRE和JDK的区别: JVM(Java Virtual Machine):java虚拟机,用于保证java的跨平台的特性. ...

  9. ab plc编程软件_三菱PLC编程程序PLC的软件编程

    三菱PLC编程程序-PLC的软件编程 BL2 RACKMOUNT 4U系列工控机 - 搭载Intel第六代core i系列CPU, I3-6100, I5-6500, I7-6700 CPU可选 - ...

  10. 快速理解编程结构_为什么系统编程全都用英文而不用中文?听完专家的解释恍然大悟!...

    全球博弈(quanqiuboyi)--不一样的观点,不一样的解读,8000万人订阅的超级微信大号.不关注时事,你将会被这个世界抛弃,点击标题下蓝字"全球博弈"关注,我们将为您提供有 ...

最新文章

  1. Apache ZooKeeper - 选举Leader源码流程深度解析
  2. Thymelaf中使用select进行消息的回显
  3. 基于c语言单片机秒表课程设计,基于c语言单片机秒表课程设计要点.doc
  4. 保险条款精解(三) 撞车
  5. TCP三次握手四次挥手过程及其中的状态量
  6. 对于相同Bean,在父应用上下文中定义的切面,在子应用上下文中会生效吗?
  7. HeadFirst设计模式笔记——命令模式
  8. python读取nc出图_python读取nc文件
  9. 6轴游戏手柄测试python程序
  10. linux h5cc 编译,雷霆传奇H5源码编译+Linux+Release+Docker_2021/02/04
  11. 快冲!淘宝无货源副业,傻瓜式操作,日赚300-500元!!
  12. 迷茫时代的明白人——书摘
  13. java俄罗斯方块七中图形类_shell脚本编写的俄罗斯方块游戏源码
  14. spark 无法读取hive 3.x的表数据
  15. XGBoost原论文阅读翻译
  16. 计算机辅助翻译专业院校,中国翻译学专业高校排名
  17. 02 食尚年华石锅土鲫鱼需求简单描述
  18. 全国计算机等级考试二级Java全真模拟
  19. 16281053_杨瑷彤_操作系统第五次实验-文件系统
  20. java swing 创建一个简单的QQ界面

热门文章

  1. java ftl导出pdf_java根据模板导出PDF详细教程
  2. Android优秀参考APP源码
  3. Java命令学习系列(六)——javap
  4. mysql 游标动态传参数_Mysql 游标施用动态变量
  5. C++转Java快速入门
  6. 佳铁精雕机连接电脑设置_佳铁精雕机在程式里怎么更改G57之后的坐标
  7. Jmeter 及 JDK 下载 安装教程
  8. 远程控制软件也要有plan B备选方案
  9. linux shell文件转码命令:iconv
  10. JAVA语言程序设计(基础篇)第十版课后题答案(第一章)