Java 9 并发编程实战
作者:[西班牙]哈维尔·费尔南德兹·冈萨雷斯
出版社:人民邮电出版社
ISBN:9787115505866
VIP会员免费
(仅需0.8元/天)
¥ 63.36
温馨提示: 价值40000元的1000本电子书,VIP会员随意看哦!
电子书推荐
-
java并发编程实战_pdf_高清晰完整版 评分:
目录 对本书的赞誉 译者序 前 言 第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 F inal域 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-ModificationException 5.1.3 隐藏迭代器 5.2 并发容器 5.2.1 ConcurrentHashMap 5.2.2 额外的原子Map操作 5.2.3 CopyOnWriteArrayList 5.3 阻塞队列和生产者-消费者模式 5.3.1 示例:桌面搜索 5.3.2 串行线程封闭 5.3.3 双端队列与工作密取 5.4 阻塞方法与中断方法 5.5 同步工具类 5.5.1 闭锁 5.5.2 FutureTask 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 CompletionService:Executor与BlockingQueue 6.3.6 示例:使用CompletionService实现页面渲染器 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 采用newTaskFor来封装非标准的取消 7.2 停止基于线程的服务 7.2.1 示例:日志服务 7.2.2 关闭ExecutorService 7.2.3 “毒丸”对象 7.2.4 示例:只执行一次的服务 7.2.5 shutdownNow的局限性 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 配置ThreadPoolExecutor 8.3.1 线程的创建与销毁 8.3.2 管理队列任务 8.3.3 饱和策略 8.3.4 线程工厂 8.3.5 在调用构造函数后再定制ThreadPoolExecutor 8.4 扩展 ThreadPoolExecutor 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 SwingWorker 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与 ReentrantLock 13.1.1 轮询锁与定时锁 13.1.2 可中断的锁获取操作 13.1.3 非块结构的加锁 13.2 性能考虑因素 13.3 公平性 13.4 在synchronized和ReentrantLock之间进行选择 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 AbstractQueuedSynchronizer 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 并发性标注 参考文献
上传时间:2018-04 大小:1.96MB
- 8.73MB
《java 并发编程实战高清PDF版》
2018-03-14深入讲解java并发编程技术,多线程、锁以及java内存模型等
- 36.34MB
Java并发编程实践 高清扫描版
2012-09-08Java并发编程实践 高清扫描版 多线程 并发 好熟
- 10.40MB
Java 并发编程实战.pdf
2019-05-28《java并发编程实战》是java并发的圣经。亲自整理目录结构,层级分明(福昕阅读器整理)。高清。
- 7.28MB
Java 9并发编程实战手册
2017-05-22Java 7并发编程实战手册的英文第二版(2017.5)
- 9.24MB
(PDF带目录)《Java 并发编程实战》,java并发实战,并发
2018-10-19这就是最正宗的《Java 并发编程实战》带目录 用福昕阅读器打开查看特别的清晰
- 8.87MB
Java 并发编程实战_2012
2017-09-21【描述】Java 并发编程实战_2012,主J要讲解并发编程相关的知识点,Java中的多线程部分以及并发处理的相关内容。 【版权声明】该资源应用与共享和交流学习,不作它用。如有侵权,请联系删除 【资源说明】改版后不能...
- 93KB
java并发编程实战源码,java并发编程实战pdf,Java
2021-09-10java并发编程实战源码 附有本书所有源码,maven 导入 eclipse或idea
- 41.74MB
Java并发编程实践高清pdf及源码
2019-03-04JAVA并发编程实践中文版 英文版 原书源码 英文版本还是不错的 英文过硬可以直接看英文版本
- 72.5MB
Java 7并发编程实战手册 pdf全本
2015-05-10本书介绍了Java并发API的方方面面,提供了使用这一新功能的必备技巧,及介绍了Java并发API的所有功能,也特别强调了在Java7版本中的新功能。本书包含60多个实用的案例和技巧,可以帮助读者快速开始实践和体验并发编程。本书作者具有十多年Java开发经验。本书译者是CSDNJava……
- 2.6MB
Java并发编程实践 PDF 高清版
2010-06-25随着多核处理器的普及,使用并发成为构建高性能应用程序的关键。Java 5以及6在开发并发程序取得了显著的进步,提高了Java虚拟机的性能,提高了并发类的可伸缩性,并加入了丰富的新并发构建块。在本书中,这些便利工具的创造者不仅解释了它们究竟如何工作、如何使用,同时,还阐释了创造它们的原因,及其背后的设计模式。 本书既能够成为读者的理论支持,又可以作为构建可靠的,可伸缩的,可维护的并发程序的技术支持。本书并不仅仅提供并发API的清单及其机制,本书还提供了设计原则,模式和思想模型,使我们能够更好地构建正确的,性能良好的并发程序。 本书的读者是那些具有一定Java编程经验的程序员、希望了解Java SE 5,6在线程技术上的改进和新特性的程序员,以及Java和并发编程的爱好者。 目录 代码清单 序 第1章 介绍 1.1 并发的(非常)简短历史 1.2 线程的优点 1.3 线程的风险 1.4 线程无处不在 第1部分 基础 第2章 线程安全 2.1 什么是线程安全性 2.2 原子性 2.3 锁 2.4 用锁来保护状态 2.5 活跃度与性能 第3章 共享对象 3.1 可见性 3.2 发布和逸出 3.3 线程封闭 3.4 不可变性 3.5 安全发布 . 第4章 组合对象 4.1 设计线程安全的类 4.2 实例限制 4.3 委托线程安全 4.4 向已有的线程安全类添加功能 4.5 同步策略的文档化 第5章 构建块 5.1 同步容器 5.2 发容器 5.3 阻塞队列和生产者一消费者模式 5.4 阻塞和可中断的方法 5.5 Synchronizer 5.6 为计算结果建立高效、可伸缩的高速缓存 第2部分 构建并发应用程序 第6章 任务执行 6.1 在线程中执行任务 6.2 Executor 框架 6.3 寻找可强化的并行性 第7章 取消和关闭 7.1 任务取消 7.2 停止基于线程的服务 7.3 处理反常的线程终止 7.4 JVM关闭 第8章 应用线程池 8.1 任务与执行策略问的隐性耦合 8.2 定制线程池的大小 8.3 配置ThreadPoolExecutor 8.4 扩展ThreadPoolExecutor 8.5 并行递归算法 第9章 GUI应用程序 9.1 为什么GUI是单线程化的 9.2 短期的GUI任务 9.3 耗时GUI任务 9.4 共享数据模型 9.5 其他形式的单线程子系统 第3部分 活跃度,性能和测试 第10章 避免活跃度危险 第11章 性能和可伸缩性 第12章 测试并发程序 第4部分 高级主题 第13章 显示锁 第14章 构建自定义的同步工具 第15章 原子变量与非阻塞同步机制 第16章 Java存储模型 附录A 同步Annotation 参考文献 索引
- 8.86MB
java并发实战pdf及demo源码
2018-09-25java并发编程实战,对理解java的多线程机制有很大的帮助
- 130KB
Java 并发编程实战-随书源码
2018-04-27Java 并发编程实战-随书源码,下载即可使用。(压缩包附有PDF链接)
- 40.58MB
Java并发编程实践.pdf
2012-04-19Java并发编程实践.pdf Java并发编程实践.pdf Java并发编程实践.pdf Java并发编程实践.pdf
- 151.57MB
62-Java并发编程实战
2023-10-1062-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java...
- 8.69MB
Java并发编程实战_java并发_
2021-10-03java并发编程讲解,并发实际使用场景介绍,理论与实践结合
- 52KB
异步编程实践_动力节点Java学院整理
2017-11-13异步编程提供了一个非阻塞的,事件驱动的编程模型。 这种编程模型利用系统中多核执行任务来提供并行,因此提供了应用的吞吐率。此处吞吐率是指在单位时间内所做任务的数量。 在这种编程方式下, 一个工作单元将独立于主应用线程而执行, 并且会将它的状态通知调用线程:成功,处理中或者失败。
- 72.5MB
Java7并发编程实战手册-高清版
2018-05-03本书仅供学习使用,不可作为商业用途。侵删 这本书介绍了Java并发API的方方面面,提供了使用这一新功能的必备技巧,及介绍了Java并发API的所有功能,也特别强调了在Java7版本中的新功能。本书包含60多个实用的案例和技巧,可以帮助读者快速开始实践和体验并发编程。本书作者具有十多年Java开发经验。
- 36.80MB
JAVA并发编程实践高清版带书签PDF
2018-01-12JAVA并发编程实践高清版带书签PDF....................
- 39.60MB
JAVA并发编程实践.pdf 带目录书签 清晰版
2013-06-15JAVA并发编程实践.pdf 带目录书签 清晰版
- 106.33MB
java并发编程2
2019-02-15java并发编程pdf文档第二部分:Java并发编程实战.pdf、Java多线程编程核心技术.pdf、实战Java高并发程序设计.pdf
- 13.21MB
java并发编程
2017-10-28本书全面介绍了如何使用Java 2平台进行并发编程,较上一版新增和扩展的内容包括:, ·存储模型 ·取消 ·可移植的并行编程 ·实现并发控制的工具类, Java平台提供了一套广泛而功能强大的api,工具和技术。内建支持线程是它的一个强大的功能。这一功能为使用Java编程语言的程序员提供了解并发编程这一诱人但同时也非常具有挑战性的选择。, 本书通过帮助读者理解有关并发编程的模式及其利弊,向读者展示了如何更精确地使用Java平台的线程模型。, 这里,读者将通过使用java.lang.thread类、synchronized和volatile关键字,以及wait、notify和notifyall方法,学习如何初始化、控制和协调并发操作。此外,本书还提供了有关并发编程的全方位的详细内容,例如限制和同步、死锁和冲突、依赖于状态的操作控制、异步消息传递和控制流、协作交互,以及如何创建基于web的服务和计算型服务。 本书的读者对象是那些希望掌握并发编程的中高级程序员。从设计模式的角度,本书提供了标准的设计技巧,以创建和实现用来解决一般性并发编程问题的组件。贯串全书的大量示例代码详细地阐述了在讨论中所涉及到的并发编程理念的细微之处。
- 1.13MB
java并发编程实践pdf笔记
2022-12-15java并发编程实战pdf学习笔记 总结了重要的知识点
- 1.99MB
Java并发编程实战华章专业开发者书库 (Tim Peierls 等 美Brian Goetz).pdf
2023-04-09java并发编程实战 pdf
- 55KB
Java异步处理简单实践
2020-12-22同步与异步 通常同步意味着一个任务的某个处理过程会对多个线程在用串行化处理,而异步则意味着某个处理过程可以允许多个线程同时处理。 异步通常代表着更好的性能,因为它很大程度上依赖于缓冲,是典型的使用空间换时间的做法,例如在计算机当中,高速缓存作为cpu和磁盘io之间的缓冲地带协调cpu高速计算能力和磁盘的低速读写能力。 volatile 应用场景:检查一个应用执行关闭或中断状态。因为此关键字拒绝了虚拟对一个变量多次赋值时的优化从而保证了虚拟机一定会检查被该关键字修饰的变量的状态变化。 CountDownLatch 应用场景:控制在一组线程操作执行完成之前当前线
- 90KB
java异步编程详解
2020-08-26主要介绍了java异步编程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧