闪存|耗时整整7天,终于把牛客网上最火的Java面试八股文整理成了面试文档( 二 )


  • Java 中会存在内存泄漏吗 , 请简单描述 。
  • 深拷贝和浅拷贝 。
  • System.gc() 和 Runtime.gc() 会做什么事情?
  • finalize() 方法什么时候被调用?析构函数 (finalization)的目的是什么?
  • 如果对象的引用被置为 null , 垃圾收集器是否会立即释放对象占用的内存?
  • 什么是分布式垃圾回收(DGC)?它是如何工作的?
  • 串行(serial)收集器和吞吐量(throughput)收集器的区别是什么?
  • 在 Java 中 , 对象什么时候可以被垃圾回收?
  • 简 述 Java 内 存分 配与 回 收策 率以 及 Minor GC 和Major GC 。
  • JVM 的永久代中会发生垃圾回收么?
  • Java 中垃圾收集的方法有哪些?
  • 什么是类加载器 , 类加载器有哪些?
  • 类加载器双亲委派模型机制?




  • 并发编程面试真题38道:
    Synchronized 相关问题:

    • Synchronized 用过吗 , 其原理是什么?
    • 你刚才提到获取对象的锁 , 这个“锁”到底是什么?如何确定对象的锁?
    • 什么是可重入性 , 为什么说 Synchronized 是可重入锁?
    • JVM 对 Java 的原生锁做了哪些优化?
    • 为什么说 Synchronized 是非公平锁?
    • 什么是锁消除和锁粗化?
    • 为什么说 Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是 CAS , 它有什么特性?
    • 乐观锁一定就是好的吗?
    可重入锁 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 需要注意些什么?





    Spring面试真题25道: