- Synchronized 用过吗,其原理是什么? synchronized是什么,用法及原理
- 你刚才提到获取对象的锁,这个“锁”到底是什么?如何确定对象的锁? Synchronized方法锁、对象锁、类锁区别
- 什么是可重入性,为什么说 Synchronized 是可重入锁? synchronized 是可重入锁吗?为什么?
- JVM 对 Java 的原生锁做了哪些优化? Java-JVM 锁优化
- 为什么说 Synchronized 是非公平锁? Synchronized
- 什么是锁消除和锁粗化?Synchronized
- 为什么说 Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是 CAS,它有什么特性? Synchronized
- 乐观锁一定就是好的吗?Synchronized
- 跟 Synchronized 相比,可重入锁 ReentrantLock 其实现原理有什么不同? Synchronized
- 那么请谈谈 AQS 框架是怎么回事儿?Synchronized
- 请尽可能详尽地对比下 Synchronized 和 ReentrantLock 的异同。 Synchronized
- ReentrantLock 是如何实现可重入性的?Synchronized
- 除了 ReetrantLock,你还接触过 JUC 中的哪些并发工具?Synchronized
- 请谈谈 ReadWriteLock 和 StampedLock。Synchronized
- 如何让 Java 的线程彼此同步?你了解过哪些同步器?请分别介绍下。 Synchronized
- CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢? Synchronized
CountDownLatch和CyclicBarrier都能够实现线程之间的等待,只不过它们的侧重点不同:
①CountDownLatch一般用于某个线程A等待若干个其他线程执行完任务之后才执行。
②CyclicBarrier一般用于一组线程互相等待至某个状态然后同时执行。
③CountDownLatch是不能重用的,而CyclicBarrier可以重用。
- Java 线程池相关问题
- Java 中的线程池是如何实现的(线程池(包含什么,core、max联系)原理?)?
- 创建线程池的几个核心构造参数?
- 线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?
- 既然提到可以通过配置不同参数创建出不同的线程池,那么 Java 中默认实现好的线程池又有哪些呢?请比较它们的异同
- 如何在 Java 线程池中提交线程?
- 什么是 Java 的内存模型,Java 中各个线程是怎么彼此看到对方的变量的?
- 请谈谈 volatile 原理以及特点,为什么它能保证变量对所有线程的可见性?
- 既然 volatile 能够保证线程间的变量可见性,是不是就意味着基于 volatile 变量的运算就是并发安全的?
- 请对比下 volatile 对比 Synchronized 的异同。 volatile与synchronized的区别
- 请谈谈 ThreadLocal 是怎么解决并发安全的? 谈谈Java中的ThreadLocal
- 很多人都说要慎用 ThreadLocal,谈谈你的理解,使用 ThreadLocal 需要注意些什么?
- JMM(主内存、工作内存、happens-before)是什么? 什么是Java内存模型中的happens-before
- 有哪些无锁数据结构?无锁实现的原理? 无锁数据结构(Lock-Free Data Structures)
- 并行和并发有什么区别?
- 线程和进程的区别?
- 守护线程是什么?
- 创建线程有哪几种方式? 多线程之创建线程有哪几种方式?
- 说一下 runnable 和 callable 有什么区别? 说说Runnable与Callable
- 线程有哪些状态?
- sleep() 和 wait() 有什么区别?
- notify()和 notifyAll()有什么区别?
- 线程的 run()和 start()有什么区别?
- 创建线程池有哪几种方式?
- 线程池都有哪些状态?
- 线程池中 submit()和 execute()方法有什么区别?
- 在 java 程序中怎么保证多线程的运行安全?
- 多线程锁的升级原理是什么?
- 什么是死锁?
- 怎么防止死锁?
- synchronized 和 Lock 有什么区别? synchronized与Lock的区别
- synchronized 和 ReentrantLock 区别是什么? ReentrantLock详解 以及与synchronized的区别
- 说一下 atomic 的原理? Java中Atomic包的实现原理及应用
- Java并发编程:Synchronized底层优化(偏向锁、轻量级锁)
- Java 并发编程:线程间的协作(wait/notify/sleep/yield/join)
- java并发编程:共享性、互斥性、原子性、可见性、有序性
- 锁实现(多线程中的锁系统(四)-谈谈自旋锁)
- cas原理 (理解cas; Java并发编程总结2——慎用CAS)
- volatile使用场景 (Java并发编程:volatile关键字解析Java 并发编程:volatile的使用及其原理)
- synchronized是什么 (Synchronized 有几种用法 ;Java并发编程:Synchronized及其实现原理)
- 重入锁
- Java线程池源码及原理