在过去的时间中,我写过Java多线程与并发的整个系列。
为了方便大家的阅读,也为了让知识更系统化,这里我单独把Java多线程与并发的整个系列一并罗列于此,希望对有用的人有用,也希望能帮助到更多的人。
以下为整个目录,希望大家喜欢!
多线程的属于面试的重灾区,需要重点掌握。
本篇主要详解以下几点:
- 线程的生命周期
- 线程状态的控制
- 多线程的5种创建方式
- 线程的3种同步方式
- 多线程引入的3种问题
Volatile的重要性非常高,需要重点掌握:
- Volatile关键字
- Java内存模型
- Volatile内存模型可见性
- Volatile的工作原理
- Volatile的源码案例
这篇我主要谈到Java线程池相关的4点:
- 为什么需要线程池
- 线程池的处理流程
- 线程池相关的核心参数
- 线程池使用的注意事项
主要讲了Java 4大常用的线程锁,整体包含如下4点:
- 多线程的缘由
- 多线程并发面临的问题
- 4种Java线程锁(线程同步):synchronized、ReentrantLock等
- Java线程锁总结
完整的讲解了Java 线程池的6大方面:
- 为什么需要线程池
- 线程池的优点
- 线程池的风险
- 线程池的实现原理
- 配置线程池大小配置
- Java提供的四种线程池实现
Synchronized经常是面试必考的了,需要重点掌握,这篇主要讲了以下五点:
- Synchronized介绍
- Synchronized的使用
- Synchronized的底层实现原理
- Synchronized的锁升级顺序
- 偏向锁、轻量级锁、重量级锁的优劣势比较
最全Java锁详解:独享锁/共享锁+公平锁/非公平锁+乐观锁/悲观锁
在Java并发场景中,会涉及到各种各样的锁
- 公平锁/非公平锁
- 可重入锁
- 独享锁/共享锁
- 乐观锁/悲观锁
- 分段锁
- 自旋锁
并容器也经常是面试必考的,这篇主要讲了以下四大点:
- 什么是同步容器
- 什么是并发容器
- 常见的7大并容器介绍:concurrenthashmap copyonwritearraylist等
- ConcurrentHashMap的底层实现机制
hashmap的重要性不需要我说了,大厂非常爱考了:
- HashMap必考点了,这篇重点详解了:
- HashMap的内部实现
- HashMap的哈希函数
- HashMap的扩容
- HashMap的Put操作
- HashMap的线程安全等
彻底搞清楚ConcurrentHashMap的实现原理(含JDK1.7和JDK1.8的区别)
concurrenthashmap面试必考了,这篇重点详解了:
- 哈希表以及应用场景
- ConcurrentHashMap与HashMap等的区别
- JDK1.7版本的CurrentHashMap的实现原理
- JDK1.8版本的CurrentHashMap的实现原理
CountDownLatch、Semaphore等4大并发工具类详解
主要讲了四大Java常用的并发工具类:
- CountDownLatch
- CyclicBarrier
- Semaphore
- Exchanger
顺便说一下,由于Java多线程与并发涉及的内容还是非常广的。
因此对于本文,今后有新的内容,我会在对这个系列进行整理补充和更改。
本文强烈建议大家【收藏】
作者简介
陈睿|mikechen,10年+大厂架构经验,就职于阿里巴巴、淘宝、百度等一线互联网大厂。
关注作者「mikechen」公众号,获取更多技术干货!
后台回复【架构】,即可获取《阿里架构师进阶专题全部合集》,后台回复【面试】即可获取《史上最全阿里Java面试题总结》