Java 并发编程共63篇

Java 并发编程是高性能应用开发的重要环节。Java 并发面试题的考察重点包括线程的创建与管理、线程池的使用、同步机制(如锁、volatile 关键字)、原子类、并发容器、AQS 框架、CAS 原理、线程安全问题的排查以及高并发场景下的性能优化。

面试题:什么是 Java 内存模型(JMM)?

Java内存模型(Java Memory Model,简称JMM)是Java语言规范中定义的一种抽象概念,它描述了程序中各个线程如何通过内存进行交互。 JMM的目标是在不同的硬件架构和操作系统之上提供一个一致的内...
程序百科的头像-程序百科程序百科1个月前
275

面试题:在 Java 中主线程如何知晓创建的子线程是否执行成功?

在Java中,主线程想要知晓其创建的子线程是否执行成功,可以通过以下几种方式来实现: 1. 使用 Thread.join() 方法 join() 方法允许一个线程等待另一个线程完成。通过调用子线程...
程序百科的头像-程序百科程序百科1个月前
277

面试题:什么是 Java 中的指令重排?

在Java中,指令重排(Instruction Reordering)是指编译器或处理器为了优化程序性能而对程序中的指令顺序进行调整的过程。 尽管这种重排通常不会改变单线程程序的行为,但在多线程环境下可能导...
程序百科的头像-程序百科程序百科1个月前
279

面试题:Java 线程池中 shutdown 与 shutdownNow 的区别是什么?

在 Java 的 ExecutorService 接口中,shutdown() 和 shutdownNow() 都是用来关闭线程池的方法,但它们的行为和效果有所不同。理解两者之间的差异对于正确管理线程池的生命周期至关重要。 shutdo...
程序百科的头像-程序百科程序百科1个月前
2715

面试题:什么是 Java 的 happens-before 规则?

在Java中,happens-before 规则是Java内存模型(JMM, Java Memory Model)的一部分,用于定义程序中操作之间的部分有序关系,确保多线程环境下的可见性和顺序性。 通过这些规则,程序员可以确定...
程序百科的头像-程序百科程序百科1个月前
2613

面试题:Java 中的 final 关键字是否能保证变量的可见性?

在Java中,final 关键字主要用于三种场景:变量、方法和类。对于 final 变量,它确实能间接地提供某种程度的可见性保证,但这并不是它的主要目的。 final 关键字的作用 不可变性:当一个变量被...
程序百科的头像-程序百科程序百科1个月前
2513

面试题:什么是 Java 的 Semaphore?

Java 中的 Semaphore 是 java.util.concurrent 包提供的一个资源访问控制工具类,用于限制同时访问的线程数量,从而实现对共享资源的并发控制。它是基于 AQS(AbstractQueuedSynchronizer) 实...
程序百科的头像-程序百科程序百科1个月前
2410

面试题:什么是 Java 的 ForkJoinPool?

Java 的 ForkJoinPool 是 Java 7 引入的一个线程池实现,专门设计用于执行可以递归分解为更小任务的工作窃取算法(work-stealing algorithm)。它特别适用于那些能够被分解成许多相似的小任务的...
程序百科的头像-程序百科程序百科1个月前
2412

面试题:你了解 Java 线程池的原理吗?

是的,我了解 Java 线程池的原理。线程池(Thread Pool)是 Java 并发编程中非常重要的一个机制,它的核心目的是复用线程、提高性能、管理并发资源。Java 中线程池的核心实现类是 ThreadPoolExe...
程序百科的头像-程序百科程序百科1个月前
2312

面试题:说说 AQS 吧?

当然可以,AQS(AbstractQueuedSynchronizer) 是 Java 并发包 java.util.concurrent(简称 JUC)中非常核心的一个抽象类,是构建各种同步器(如 ReentrantLock、Semaphore、CountDownLatch、Re...
程序百科的头像-程序百科程序百科1个月前
2211