内容推荐 并发编程相比Java中其他知识点的学习门槛较高,从而导致很多人望而却步。但无论是职场面试,还是高并发/ 高流量系统的实现,却都离不开并发编程,于是能够真正掌握并发编程的人成为了市场迫切需求的人才。 翟陆续、薛宾田著的《Java并发编程之美》通过图文结合、通俗易懂的讲解方式帮助大家完成多线程并发编程从入门到实践的飞跃!全书分为三部分,第一部分为Java并发编程基础篇,主要讲解Java并发编程的基础知识、线程有关的知识和并发编程中的其他相关概念,这些知识在高级篇都会有所使用,掌握了本篇的内容,就为学习高级篇奠定了基础;第二部分为Java并发编程高级篇,讲解了Java并发包中核心组件的实现原理,让读者知其然,也知其所以然,熟练掌握本篇内容,对我们在日常开发高并发、高流量的系统时会大有裨益;第三部分为Java并发编程实践篇,主要讲解并发组件的使用方法,以及在使用过程中容易遇到的问题和解决方法。 本书适合Java初级、中高级研发工程师,对Java并发编程感兴趣,以及希望探究JUC包源码原理的人员阅读。 目录 第一部分 Java 并发编程基础篇 第1章 并发编程线程基础 1.1 什么是线程 1.2 线程创建与运行 1.3 线程通知与等待 1.4 等待线程执行终止的join 方法 1.5 让线程睡眠的sleep 方法 1.6 让出CPU 执行权的yield 方法 1.7 线程中断 1.8 理解线程上下文切换 1.9 线程死锁 1.9.1 什么是线程死锁 1.9.2 如何避免线程死锁 1.10 守护线程与用户线程 1.11 ThreadLocal 1.11.1 ThreadLocal 使用示例 1.11.2 ThreadLocal 的实现原理 1.11.3 ThreadLocal 不支持继承性 1.11.4 InheritableThreadLocal 类 第2章 并发编程的其他基础知识 2.1 什么是多线程并发编程 2.2 为什么要进行多线程并发编程 2.3 Java 中的线程安全问题 2.4 Java 中共享变量的内存可见性问题 2.5 Java 中的synchronized 关键字 2.5.1 synchronized 关键字介绍 2.5.2 synchronized 的内存语义 2.6 Java 中的volatile 关键字 2.7 Java 中的原子性操作 2.8 Java 中的CAS 操作 2.9 Unsafe 类 2.9.1 Unsafe 类中的重要方法 2.9.2 如何使用Unsafe 类 2.10 Java 指令重排序 2.11 伪共享 2.11.1 什么是伪共享 2.11.2 为何会出现伪共享 2.11.3 如何避免伪共享 2.11.4 小结 2.12 锁的概述 2.12.1 乐观锁与悲观锁 2.12.2 公平锁与非公平锁 2.12.3 独占锁与共享锁 2.12.4 什么是可重入锁 2.12.5 自旋锁 2.13 总结 第二部分 Java 并发编程高级篇 第3章 Java 并发包中ThreadLocalRandom 类原理剖析 3.1 Random 类及其局限性 3.2 ThreadLocalRandom 3.3 源码分析 3.4 总结 第4章 Java 并发包中原子操作类原理剖析 4.1 原子变量操作类 4.2 JDK 8 新增的原子操作类LongAdder 4.2.1 LongAdder 简单介绍 4.2.2 LongAdder 代码分析 4.2.3 小结 4.3 LongAccumulator 类原理探究 4.4 总结 第5章 Java 并发包中并发List 源码剖析 5.1 介绍 5.2 主要方法源码解析 5.2.1 初始化 5.2.2 添加元素 5.2.3 获取指定位置元素 5.2.4 修改指定元素 5.2.5 删除元素 5.2.6 弱一致性的迭代器 5.3 总结 第6章 Java 并发包中锁原理剖析 6.1 LockSupport 工具类 6.2 抽象同步队列AQS 概述 6.2.1 AQS——锁的底层支持 6.2.2 AQS——条件变量的支持 6.2.3 基于AQS 实现自定义同步器 6.3 独占锁ReentrantLock 的原理 6.3.1 类图结构 6.3.2 获取锁 6.3.3 释放锁 6.3.4 案例介绍 6.3.5 小结 6.4 读写锁ReentrantReadWriteLock 的原理 6.4.1 类图结构 6.4.2 写锁的获取与释放 6.4.3 读锁的获取与释放 6.4.4 案例介绍 6.4.5 小结 6.5 JDK 8 中新增的StampedLock 锁探究 6.5.1 概述 6.5.2 案例介绍 6.5.3 小结 第7章 Java 并发包中并发队列原理剖析 7.1 ConcurrentLinkedQueue 原理探究 7.1.1 类图结构 7.1.2 ConcurrentLinkedQueue 原理介绍 7.1.3 小结 7.2 LinkedBlockingQueue 原理探究 7.2.1 类图结构 7.2.2 LinkedBlockingQueue 原理介绍 7.2.3 小结 7.3 ArrayBlockingQueue 原理探究 7.3.1 类图结构 7.3.2 ArrayBlockingQueue 原理介绍 7.3.3 小结 7.4 PriorityBlockingQueue 原理探究 7.4.1 介绍 7.4.2 PriorityBlockingQueue 类图结构 7.4.3 原理介绍 7.4.4 案例介绍 7.4.5 小结 7.5 DelayQueue 原理探究 7.5.1 DelayQueue 类图结构 7.5.2 主要函数原理讲解 7.5.3 案例介绍 7.5.4 小结 第8章 Java 并发包中线程池ThreadPoolExecutor 原理探究 8.1 介绍 8.2 类图介绍 8.3 源码分析 8.3.1 public void execute(Runnable command) 8.3.2 工作线程Worker 的执行 8.3.3 shutdown 操作 8.3.4 shutdownNow 操作 8.3.5 awaitTermination 操作 8.4 总结 第9章 Java 并发包中ScheduledThreadPoolExecutor 原理探究 9.1 介绍 9.2 类图介绍 9.3 原理剖析 9.3.1 schedule(Runnable command, long delay,TimeUnit unit) 方法 9.3.2 scheduleWithFixedDelay(Runnable command,long initialDelay, long delay,TimeUnit unit) 方法
|