排序
面试题:什么是 Java 的 happens-before 规则?
在Java中,happens-before 规则是Java内存模型(JMM, Java Memory Model)的一部分,用于定义程序中操作之间的部分有序关系,确保多线程环境下的可见性和顺序性。 通过这些规则,程序员可以确定...
面试题:Synchronized 修饰静态方法和修饰普通方法有什么区别?
在 Java 中,synchronized 关键字可以用来修饰实例方法、静态方法或者代码块。当它用于修饰静态方法和普通(实例)方法时,存在一些重要的区别,主要体现在锁的对象以及锁定的范围上。 锁定对象...
面试题:如何优化 Java 中的锁的使用?
在 Java 中优化锁的使用可以显著提高应用程序的性能,尤其是在高并发场景下。以下是一些优化锁使用的策略: 减少锁的作用域:尽量缩小同步代码块的范围,只锁定必要的代码段,而不是整个方法。...
面试题:什么是 Java 的 Semaphore?
Java 中的 Semaphore 是 java.util.concurrent 包提供的一个资源访问控制工具类,用于限制同时访问的线程数量,从而实现对共享资源的并发控制。它是基于 AQS(AbstractQueuedSynchronizer) 实...
面试题: Synchronized 能不能禁止指令重排序?
在 Java 中,Synchronized 关键字主要用于确保线程安全,它通过提供可见性和原子性来保证共享资源的正确访问。 关于 Synchronized 是否能禁止指令重排序,我们需要从 Java 内存模型(JMM, Java ...
面试题:什么是 Java 内存模型(JMM)?
Java内存模型(Java Memory Model,简称JMM)是Java语言规范中定义的一种抽象概念,它描述了程序中各个线程如何通过内存进行交互。 JMM的目标是在不同的硬件架构和操作系统之上提供一个一致的内...
面试题:什么是 Java 的 ForkJoinPool?
Java 的 ForkJoinPool 是 Java 7 引入的一个线程池实现,专门设计用于执行可以递归分解为更小任务的工作窃取算法(work-stealing algorithm)。它特别适用于那些能够被分解成许多相似的小任务的...
面试题: Java 中 ReentrantLock 的实现原理是什么?
ReentrantLock 是 Java 提供的一个显式锁实现,位于 java.util.concurrent.locks 包中。 它提供了与 synchronized 类似的同步功能,但相比 synchronized,它更加灵活,并提供了更多的特性,如公...
面试题:Java 中的 List 接口有哪些实现类?
Java中的 List 接口有多个实现类,每个实现类都有其特定的使用场景和特性。以下是一些常见的 List 实现类: ArrayList 基于动态数组的数据结构。 支持对元素的快速随机访问...
面试题:Java 中的 final 关键字是否能保证变量的可见性?
在Java中,final 关键字主要用于三种场景:变量、方法和类。对于 final 变量,它确实能间接地提供某种程度的可见性保证,但这并不是它的主要目的。 final 关键字的作用 不可变性:当一个变量被...
