JAVA并发编程实践(电子工业出版社)
描述:
433
内容:
目录
倾鱗I
序VII
第1 章介绍1
1.1 并发的(非常)简短历史1
1.2 线程的优点3
1.3 线程的风险5
1.4 线程无处不在9
第1 部分基础1 3
第2 章线程安全1 5
2.1 什么是线程安全性17
2.2 原子性19
2 . 3 锁23
2.4 用锁来保护状态27
2.5 活跃度与性能29
第3 章共享对象3 3
3.1 nliSltt 33
3.2 发布和逸出39
3.3 线程封闭42
3.4 fW变性46
3.5 安全发布49
第4 章组合对象5 5
4.1 设计线程安全的类55
4.2 实例限制58
4,3 委托线程安全62
4.4 向已有的线程安全类添加功能71
Java并发銷实践
xvi @录
4.5 同步策略的文档化74
第5 章构建块79
5.1 同步容器79
5.2 并发容器84
5.3 阻塞队列和生产者-消费者模式87
5.4 阻塞和可中断的方法92
5.5 Synchronizer 94
5.6 为计算结果建立高效、可伸缩的高速缓存101
第2 部分构建并发应用程序111
第6 章任务执行1 1 3
6.1 在线程中执行任务113
6.2 Executor 框架117
6.3 寻找可强化的并行性123
第7 章取消和关闭1 3 5
7.1 任务取消135
7.2 停止基于线程的服务150
7.3 处理反常的线程终止161
7.4 JVM 关闭164
第8 章应用线程池1 6 7
8.1 任务与执行策略间的隐性耦合167
8.2 定制线程池的大小170
8.3 配置ThreadPoolExecutor 171
8.4 扩展ThreadPoolExecutor 179
8.5 并行递归算法181
第9 章GUI 应用程序189
9.1 为什么GUI 是单线程化的189
9.2 短期的GUI 任务192
9.3 耗时GUI 任务195
9.4 共享数据模型198
9.5 其他形式的单线程子系统202
Java并发编程实践
巨录xvii
第3 部分活跃度,性能和测试2 0 3
第10 章避免活跃度危险2 0 5
10.1 麵205
10.2 避免和诊断死锁215
10.3 其他的活跃度危险218
第1 1 章性能和可伸缩性2 2 1
11.1 性能的思考221
11.2 Amdahl 定律225
11.3 线程引入的开销229
11.4 减少锁的竞争232
11.5 示例:比较Map 的性能242
11.6 减少上下文切换的开销243
第1 2 章测试并发程序247
12.1 测试正确性248
12.2 测试性能260
12.3 避免性能测试的陷阱266
12.4 测试方法补遗270
第4 部分高级主题2 7 5
第1 3 章显式锁277
13.1 Lock 和ReentrantLock 277
13.2 对性能的考量282
13.3 公平性283
13.4 在synchronized 和ReentrantLock 之间进行选择285
13.5 读-写锁286
第1 4 章构建自定义的同步工具2 9 1
14.1 管理状态依赖性291
14.2 使用条件队列298
14.3 显式的Condition 对象306
14.4 剖析Synchronizer 308
14.5 AbstractQueuedSynchronizer 311
14.6 java.util.concurrent 的Synchronizer 类中的AQS 314
Java并发编程实践
xviii @5
第丨5 章原子变量与非阻塞同步机制319
15.1 锁的劣势319
15.2 硬件对并发的支持321
15.3 原子变量类324
15.4 非阻塞算法329
第16 章Java 存储模型337
16.1 什么是存储模型,要它何用337
16.2 344
16.3 初始化安全性349
附录A 同步Annotation 353
A.1 类Annotation 353
A.2 域Annotation 和方法Annotation 353
参考文献355
**** Hidden Message *****
链接:http://pan.baidu.com/s/1boFJOrP 密码:**** Hidden Message *****
感谢楼主分享,么么哒~!
感谢楼主分享,么么哒~! 谢谢分享! 学习学习
感谢楼主分享
学习一下并发!
谢谢分享 谢谢楼主。。。。。
66666666663