前言
众所周知, 在 Java 的知识体系中, 并发编程是非常重要的一环, 也是面试的必问题, 一个好的 Java 程序员是必须对并发编程这块有所了解的.
然而不论是哪个国家, 什么背景的 Java 开发者, 都对自己写的并发程序相当自信, 但也会在出问题时表现得很诧异甚至一筹莫展.
可见, Java 并发编程显然不是一件能速成的能力, 基础搭得越好, 越全面, 在实践中才会有更深刻的理解.
因此, 大家不难发现 Java 并发问题一直是各个大厂面试的重点之一. 我在平时的面试中, 也发现很多候选人对一些基本的并发概念表示没听过, 或原理不理解, 可能知道一些却又讲不清楚, 最终导致面试失败.
本文会结合实际中接触到的一些面试题, 重点来聊一聊 Java 并发中的相关知识点.
Synchronized 相关问题
问题一: Synchronized 用过吗, 其原理是什么?
问题二: 你刚才提到获取对象的锁, 这个 "锁" 到底是什么? 如何确定对象的锁?
问题三: 什么是可重入性, 为什么说 Synchronized 是可重入锁?
问题四: JVM 对 Java 的原生锁做了哪些优化?
问题五: 为什么说 Synchronized 是非公平锁?
问题六: 什么是锁消除和锁粗化?
问题七: 为什么说 Synchronized 是一个悲观锁? 乐观锁的实现原理又是什么? 什么是
问题八: 乐观锁一定就是好的吗?
可重入锁 ReentrantLock 及其他显式锁相关问题
问题一: 跟 Synchronized 相比, 可重入锁 ReentrantLock 其实现原理有什么不同?
问题二: 那么请谈谈 AQS 框架是怎么回事儿?
问题三: 请尽可能详尽地对比下 Synchronized 和 ReentrantLock 的异同.
问题四: ReentrantLock 是如何实现可重入性的?
问题五: 除了 ReetrantLock, 你还接触过 JUC 中的哪些并发工具?
问题六: 请谈谈 ReadWriteLock 和 StampedLock.
问题七: 如何让 Java 的线程彼此同步? 你了解过哪些同步器? 请分别介绍下.
问题八: CyclicBarrier 和 CountDownLatch 看起来很相似, 请对比下呢?
Java 线程池相关问题
问题一: Java 中的线程池是如何实现的?
问题二: 创建线程池的几个核心构造参数?
问题三: 线程池中的线程是怎么创建的? 是一开始就随着线程池的启动创建好的吗?
问题四: 既然提到可以通过配置不同参数创建出不同的线程池, 那么 Java 中默认实现好的线程池又有哪些呢? 请比较它们的异同.
问题五: 如何在 Java 线程池中提交线程?
Java 内存模型相关问题
问题一: 什么是 Java 的内存模型, Java 中各个线程是怎么彼此看到对方的变量的?
问题二: 请谈谈 volatile 有什么特点, 为什么它能保证变量对所有线程的可见性?
问题三: 既然 volatile 能够保证线程间的变量可见性, 是不是就意味着基于 volatile 变量的运算就是并发安全的?
问题四: 请对比下 volatile 对比 Synchronized 的异同.
问题五: 请谈谈 ThreadLocal 是怎么解决并发安全的?
问题六: 很多人都说要慎用 ThreadLocal, 谈谈你的理解, 使用 ThreadLocal 需要注意些什么?
如何学习并发编程
学习 java 并发就像进入了另外一个学习领域, 就像学习一门新的编程语言, 或者是学习一套新的语言概念, 要理解并发编程, 其难度跟理解面向对象编程难度差不多. 你花一点功夫, 就可以理解它的基本机制, 但是要想真正掌握它的本质, 就需要深入的学习与理解. 最后在分享一个并发编程知识的学习导图给大家!
结语
最后我把这些实际遇到的并发编程面试题及常见问题的答案总结了一下, 由于文字过多, 就单独做了一个文档. 以及准备了一些更多关于 Kafka,MySQL,Tomcat,Docker,Spring,MyBatis,Nginx,Netty,Dubbo,Redis,Netty,Spring cloud, 分布式, 高并发, 性能调优, 微服务等架构面试题和架构资料在群里免费分享, 如有需要的朋友的可以来免费领取, 同时可以点下喜欢和关注, 以后还会分享更多干货的!
资料获取方式: 加 QQ 群: 935692859 免费领取!
来源: http://www.jianshu.com/p/b95d6304cc88