Java 并发编程共63篇

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

面试题:什么是 Java 中的原子性、可见性和有序性?

在 Java 并发编程中,原子性(Atomicity)、可见性(Visibility)和有序性(Ordering) 是 Java 内存模型(Java Memory Model, 简称 JMM)中保障多线程程序正确执行的三大核心特性。它们分别解...
程序百科的头像-程序百科程序百科11个月前
6210

面试题:什么是 Java 的 Timer?

在 Java 中,Timer 是一个用于调度未来某个时间点执行一次或周期性执行任务的工具类。它位于 java.util 包中,通过创建一个后台线程来执行计划的任务。 尽管 Timer 类提供了一种相对简单的方式...
程序百科的头像-程序百科程序百科11个月前
6113

面试题:Java 线程池内部任务出异常后,如何知道是哪个线程出了异常?

在 Java 中,当你使用线程池(如 ThreadPoolExecutor 或其更高级别的封装如 Executors.newFixedThreadPool() 等)执行任务时,如果任务内部抛出了未捕获的异常,默认情况下这个异常不会直接反馈...
程序百科的头像-程序百科程序百科11个月前
5912

面试题:什么是 Java 的 CAS(Compare-And-Swap)操作?

CAS(Compare-And-Swap) 是一种原子操作,用于实现无锁(lock-free)数据结构和算法。它在多线程编程中扮演着非常重要的角色,特别是在需要保证线程安全的情况下避免使用传统的锁机制带来的性...
程序百科的头像-程序百科程序百科11个月前
598

面试题:你了解 Java 中的读写锁吗?

是的,Java 中的读写锁(ReadWriteLock)是一种并发控制机制,它允许多个线程同时读取共享资源,但写操作必须独占锁。这种设计在“读多写少”的场景下能显著提高并发性能。以下是关于 Java 中读...
程序百科的头像-程序百科程序百科11个月前
589

面试题:Java 中使用 ThreadLocal 的最佳实践是什么?

使用 ThreadLocal 变量时,遵循一些最佳实践可以帮助避免常见的陷阱和问题,同时最大化其优势。以下是使用 ThreadLocal 的一些最佳实践: 1. 初始化时机 尽早初始化:如果可能的话,在声明的同...
程序百科的头像-程序百科程序百科11个月前
5815

面试题:你使用过 Java 中的哪些阻塞队列?

在 Java 中,阻塞队列(BlockingQueue) 是 java.util.concurrent 包下的一个接口,它是线程安全、支持阻塞操作的队列,常用于生产者-消费者模型等并发场景。 我在项目中使用过以下几种常见的 ...
程序百科的头像-程序百科程序百科11个月前
5711

面试题:ThreadLocal 的缺点?

尽管 ThreadLocal 提供了线程本地存储的能力,使得每个线程可以拥有变量的一个独立初始化的副本,但它也存在一些缺点和潜在的问题: 1. 内存泄漏风险 类加载器相关的内存泄漏:如果 ThreadLocal...
程序百科的头像-程序百科程序百科11个月前
5611

面试题:Java 中的 wait、notify 和 notifyAll 方法有什么作用?

在Java中,wait()、notify() 和 notifyAll() 方法是用于线程间通信的关键方法,它们都定义在 Object 类中,并且必须与同步机制(如 synchronized 方法或代...
程序百科的头像-程序百科程序百科11个月前
5411

面试题:什么是 Java 的 TransmittableThreadLocal?

TransmittableThreadLocal 是阿里巴巴开源的 transmittable-thread-local 库中提供的一个类,它扩展了 Java 标准库中的 InheritableThreadLocal,旨在解决在使用线程池等会复用线程的技术时,父...
程序百科的头像-程序百科程序百科11个月前
548