下载 >  开发技术 >  Java > Java Concurrency

Java Concurrency

java 多线程并发的一本好书,值得推荐
2009-06-11 上传大小:1.16MB
分享
收藏 举报
Java Concurrency in Practice 无水印pdf

Java Concurrency in Practice 英文无水印pdf pdf所有页面使用FoxitReader和PDF-XChangeViewer测试都可以打开 本资源转载自网络,如有侵权,请联系上传者或csdn删除 本资源转载自网络,如有侵权,请联系上传者或csdn删除

立即下载
Java Concurrency in Practice(英文版+中文版)

一本关于Java线程并发编程的经典书籍,内含英文和中文双版,可以下载!

立即下载
Java.Concurrency.in.Practice.pdf

Java.Concurrency.in.Practice.pdf

立即下载
Java Concurrency in Practice Java并发编程实践 中英文版

Java并发编程实践,压缩包包含其中文版、英文版及书中的代码示例。喜欢本书请购买正版,英文原版及中文译本目录如下: 目录 英文原版: Listings xii Preface xvii Chapter 1: Introduction 1 1.1 A (very) brief history of concurrency 1 1.2 Benefits of threads 3 1.3 Risks of threads 5 1.4 Threads are everywhere 9 Part I: Fundamentals 13 Chapter 2: Thread Safety 15 2.1 What is thread safety? 17 2.2 Atomicity 19 2.3 Locking 23 2.4 Guarding state with locks 27 2.5 Liveness and performance 29 Chapter 3: Sharing Objects 33 3.1 Visibility 33 3.2 Publication and escape 39 3.3 Thread confinement 42 3.4 Immutability 46 3.5 Safepublication 49 Chapter 4: Composing Objects 55 4.1 Designing a thread-safe class 55 4.2 Instance confinement 58 4.3 Delegating thread safety 62 4.4 Adding functionality to existing thread-safe classes 71 4.5 Documenting synchronization policies 74 Chapter 5: Building Blocks 79 5.1 Synchronized collections 79 5.2 Concurrent collections 84 5.3 Blocking queues and the producer-consumer pattern 87 5.4 Blocking and interruptible methods 92 5.5 Synchronizers 94 5.6 Building an efficient, scalable result cache 101 Part II: Structuring Concurrent Applications 111 Chapter 6: Task Execution 113 6.1 Executing tasks in threads 113 6.2 The Executor framework 117 6.3 Finding exploitable parallelism 123 Chapter 7: Cancellation and Shutdown 135 7.1 Task cancellation 135 7.2 Stopping a thread-based service 150 7.3 Handling abnormal thread termination 161 7.4 JVM shutdown 164 Chapter 8: Applying Thread Pools 167 8.1 Implicit couplings between tasks and execution policies 167 8.2 Sizing thread pools 170 8.3 Configuring ThreadPoolExecutor 171 8.4 Extending ThreadPoolExecutor 179 8.5 Parallelizing recursive algorithms 181 Chapter 9: GUI Applications 189 9.1 Why are GUIs single-threaded? 189 9.2 Short-running GUI tasks 192 9.3 Long-running GUI tasks 195 9.4 Shared data models 198 9.5 Other forms of single-threaded subsystems 202 Part III: Liveness, Performance, and Testing 203 Chapter 10: Avoiding Liveness Hazards 205 10.1 Deadlock 205 10.2 Avoiding and diagnosing deadlocks 215 10.3 Other liveness hazards 218 Chapter 11: Performance and Scalability 221 11.1 Thinking about performance 221 11.2 Amdahl's law 225 11.3 Costs introduced by threads 229 11.4 Reducing lock contention 232 11.5 Example: Comparing Map performance 242 11.6 Reducing context switch overhead 243 Chapter 12: Testing Concurrent Programs 247 12.1 Testing for correctness 248 12.2 Testing for performance 260 12.3 Avoiding performance testing pitfalls 266 12.4 Complementary testing approaches 270 Part IV: Advanced Topics 275 Chapter 13: Explicit Locks 277 13.1 Lock and ReentrantLock 277 13.2 Performance considerations 282 13.3 Fairness 283 13.4 Choosing between synchronized and ReentrantLock 285 13.5 Read-write locks 286 Chapter 14: Building Custom Synchronizers 291 14.1 Managing state dependence 291 14.2 Using condition queues 298 14.3 Explicit condition objects 306 14.4 Anatomy of a synchronizer 308 14.5 AbstractQueuedSynchronizer 311 14.6 AQS in java.util.concurrent synchronizer classes 314 Chapter15: Atomic Variables and Nonblocking Synchronization 319 15.1 Disadvantages of locking 319 15.2 Hardware support for concurrency 321 15.3 Atomic variable classes 324 15.4 Nonblocking algorithms 329 Chapter 16: The Java Memory Model 337 16.1 What is a memory model, and why would I want one? 337 16.2 Publication 344 16.3 Initialization safety 349 Appendix A: Annotations for Concurrency 353 A.1 Class annotations 353 A.2 Field andmethod annotations 353 Bibliography 355 Index 359 中文译本: 对本书的赞誉 译者序 前 言 第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 Concurrency in Practice》中文版笔记.pdf

java并发编程实战《Java Concurrency in Practice》中文版笔记.pdf

立即下载
Java Concurrency in Practice电子书PDF加源码包

含下列3本电子书和2个源码jar, Java并发编程实战.pdf Java并发编程实践(全).pdf java_concurrency_in_practice.pdf jcip-examples-src.jar jcip-annotations-src.jar 英文版是高清晰的,实战和实践都是同一帮人对英文版书的翻译,网传实战的翻译质量更好,实战是2012年出版的,应该是对前一版实践翻译的改进。此资源仅供学习方便使用,请支持正版。 源码下载地址:http://jcip.net.s3-website-us-east-1.amazonaws.com/ 源码没有按章节组织,如果需要按章节查找方便的话,请看下面网址提供的源码:http://jcip.net.s3-website-us-east-1.amazonaws.com/listings.html

立即下载
Master concurrency programming java 9 2nd.pdf

Concurrency programming allows several large tasks to be divided into smaller sub-tasks, which are further processed as individual tasks that run in parallel. Java 9 includes a comprehensive API with lots of ready-to-use components for easily implementing powerful concurrency applications, but with high flexibility so you can adapt these components to your needs.

立即下载
java concurrency in practice (中文版)

java concurrency in practice (中文版)、JAVA并发编程实践-cn (中文版)

立即下载
Master concurrency programming java 9 2nd.epub

The Executor framework, to control the execution of a lot of tasks The Phaser class, to execute tasks that can be divided into phases The fork/join framework, to execute that tasks that solve a problem using the divide and conquer technique The Stream API, to process big sources of data, including the new reactive streams Concurrent data structures, to store the data in concurrent applications Synchronization mechanisms, to organize concurrent tasks

立即下载
Java Threads and the Concurrency Utilities

Java Threads and the Concurrency Utilities Java Threads and the Concurrency Utilities Java Threads and the Concurrency Utilities

立即下载
Concurrency In Action (C++并发编程)中英文版+源码

中英文版+源码 (注:中文版为陈晓伟翻译,此版本较好,非人民邮电出版的《C++并发编程实战》)

立即下载
Scala Applied Machine Learning .pdf

Java 9 Concurrency Cookbook Second Edition Java 9 Concurrency Cookbook Second Edition Java 9 Concurrency Cookbook Second Edition

立即下载
Java 9 Concurrency Cookbook, 2nd Edition

Java 9 Concurrency Cookbook Second Edition Java 9 Concurrency Cookbook Second Edition Java 9 Concurrency Cookbook Second Edition

立即下载
C++ Concurrency in Action中文版 高清无广告

本书概述 作为对《C++ Concurrency in Action》的中文翻译。 本书是基于C++11新标准的并发和多线程编程深度指南。 从std::thread、std::mutex、std::future和std::async等基础类的使用,到内存模型和原子操作、基于锁和无锁数据结构的构建,再扩展到并行算法、线程管理,最后还介绍了多线程代码的测试工作。 本书的附录部分还对C++11新语言特性中与多线程相关的项目进行了简要的介绍,并提供了C++11线程库的完整参考。 本书适合于需要深入了解C++多线程开发的读者,以及使用C++进行各类软件开发的开发人员、测试人员。 对于使用第三方线程库的读者,也可以从本书后面的章节中了解到相关的指引和技巧。 同时,本书还可以作为C++11线程库的参考工具书。 书与作者 Anthony Williams是BSI C++小组的成员,拥有10多年C++应用经验。 如今多核芯处理器使用的越来越普遍。C++11标准支持多线程,这就需要程序员掌握多线程编程的原则、技术和新语言中的并发特性,确保自己处于时代前沿。 无论你的C++技术如何,本书都会指引你使用C++11写出健壮和优雅的多线程应用。本书将会探讨线程的内存模型,新的多线程库,启动线程和同步工具。在这个过程中,我们会了解并发程序中较为棘手的一些问题。 内容的大体结构: C++11编程 多核芯编程 简单例子用于学习,复杂例子用于实践 本书是为C++程序员所写,同僚中可能有人对并发还没什么了解,估计也有人已经使用其他语言、API或平台写过多线程程序。不过,在看本书的时候,你们都在同一“起跑线”上。 访问本书论坛曼宁-C++ Concurrency in Action可获取免费试读章节电子书。 本书相关 github 翻译地址:https://github.com/xiaoweiChen/Cpp_Concurrency_In_Action gitbook 在线阅读:http://chenxiaowei.gitbooks.io/cpp_concurrency_in_action/ 书中源码:https://github.com/bsmr-c-cpp/Cpp-Concurrency-in-Action 学习C++11/14: http://www.bogotobogo.com/cplusplus/C11

立即下载
Java Concurrency in Practice JAVA并发编程实践(中英文版)

Java Concurrency in Practice JAVA并发编程实践(中英文版)Java Concurrency in Practice JAVA并发编程实践(中英文版)

立即下载
Java Concurrency in Practice JAVA并发编程实践中文版(全)

Java Concurrency in Practice JAVA并发编程实践中文版(全)第二部分

立即下载
Concurrency In Go: Tools And Techniques For Developers PDF

1,非扫描。2,纯英文。3,PDF格式。4,带目录。 Perface: “Hey, welcome to Concurrency in Go! I’m delighted that you’ve picked up this book and excited to join you in exploring the topic of concurrency in Go over the next six chapters! Go is a wonderful language. When it was first announced and birthed into the world, I remember exploring it with great interest: it was terse, compiled incredibly fast, performed well, supported duck typing, and — to my delight — I found working with its concurrency primitives to be intuitive. The first time I used the go keyword to create a goroutine (something we’ll cover, I promise!) I got this silly grin on my face. I had worked with concurrency in several languages, but I had never worked in a language that made concurrency so easy (which is not to say they don’t exist; I just hadn’t used any). I had found my way to Go. Over the years I moved from writing personal scripts ” ......

立即下载
《Java 7 Concurrency Cookbook》英文

《Java 7 Concurrency Cookbook》教程及代码。 《Java 7 Concurrency Cookbook》这本书不错,每节一个实例。 《Java Concurrency in Practice》这本书理论比较多,有点难懂,适合高级水平吧。 Book review: http://www.mkyong.com/book-review/review-java-7-concurrency-cookbook/

立即下载
Effective java

oshua Bloch是Google公司的首席Java架构师。是Jolt大奖的获得者。他曾是Sun公司的杰出工程师,和Transarc公司的高级系统设计师。Bloch曾带领团队设计和实现过无数的Java平台特性,包括JDK 5.0语言增强版和获奖的Java Collections Framework。他的著作还包括:《Java Puzzlers》、《Java Concurrency in Practive》等。

立即下载
Concurrency in Go中文版.pdf

Concurrency in Go中文版.pdf,主要用于Go并发编程学习。

立即下载
关闭
img

spring mvc+mybatis+mysql+maven+bootstrap 整合实现增删查改简单实例.zip

资源所需积分/C币 当前拥有积分 当前拥有C币
5 0 0
点击完成任务获取下载码
输入下载码
为了良好体验,不建议使用迅雷下载
img

Java Concurrency

会员到期时间: 剩余下载个数: 剩余C币: 剩余积分:0
为了良好体验,不建议使用迅雷下载
VIP下载
您今日下载次数已达上限(为了良好下载体验及使用,每位用户24小时之内最多可下载20个资源)

积分不足!

资源所需积分/C币 当前拥有积分
您可以选择
开通VIP
4000万
程序员的必选
600万
绿色安全资源
现在开通
立省522元
或者
购买C币兑换积分 C币抽奖
img

资源所需积分/C币 当前拥有积分 当前拥有C币
5 4 45
为了良好体验,不建议使用迅雷下载
确认下载
img

资源所需积分/C币 当前拥有积分 当前拥有C币
5 0 0
为了良好体验,不建议使用迅雷下载
VIP和C币套餐优惠
img

资源所需积分/C币 当前拥有积分 当前拥有C币
5 4 45
您的积分不足,将扣除 10 C币
为了良好体验,不建议使用迅雷下载
确认下载
下载
您还未下载过该资源
无法举报自己的资源

兑换成功

你当前的下载分为234开始下载资源
你还不是VIP会员
开通VIP会员权限,免积分下载
立即开通

你下载资源过于频繁,请输入验证码

您因违反CSDN下载频道规则而被锁定帐户,如有疑问,请联络:webmaster@csdn.net!

举报

若举报审核通过,可返还被扣除的积分

  • 举报人:
  • 被举报人:
  • *类型:
    • *投诉人姓名:
    • *投诉人联系方式:
    • *版权证明:
  • *详细原因: