Java面试重点:垃圾回收算法与线程池创建

需积分: 10 0 下载量 152 浏览量 更新于2024-09-03 收藏 32KB DOCX 举报
"本文档是博主Tronhon在2019年实习和秋招期间对百度、阿里巴巴等公司面试经验的总结,主要关注Java技术层面的问题。文章中讨论了垃圾收集的两种主要算法——引用计数法和可达性分析算法,并介绍了GC-Roots对象的类型。此外,还对比了Oracle与MySQL数据库的区别,以及在Java中创建线程池的几种方式。" 在Java编程中,垃圾收集是自动内存管理的关键部分,它负责识别并释放不再使用的对象以避免内存泄漏。文章提到了两种主要的垃圾收集算法: 1. 引用计数法:此算法为每个对象维护一个引用计数,当引用增加时计数加一,引用消失时减一。当计数为零时,对象被视为可回收。尽管这种方法简单且效率高,但无法处理循环引用的问题,如对象A引用对象B,B又引用A,导致两者都无法被正确回收。 2. 可达性分析算法:Java和C#采用此算法,从一组称为GC-Roots的对象开始,如果一个对象不能从GC-Roots通过引用链到达,那么该对象被认为是不可达的,可以被回收。GC-Roots通常包括虚拟机栈、方法区的静态属性和常量引用、本地方法栈中的JNI引用等。 数据库方面,Oracle和MySQL有显著的差异: - 用户标识:Oracle基于用户,而MySQL允许一个用户拥有多个数据库,每个数据库包含多张表。 - SQL语法:Oracle的语法更严格,不支持MySQL中的`LIMIT`关键字,分页操作相对复杂。 - 隔离级别:Oracle默认为读已提交,MySQL则是可重复读,这影响了并发事务的可见性和一致性。 创建线程池是Java多线程编程中的常见需求,Java提供了多种工厂方法: 1. `newFixedThreadPool(int nThreads)`:创建一个线程数量固定的线程池,所有任务将在固定数量的线程中执行,适合处理长期存在的任务。 2. `newSingleThreadExecutor()`:创建一个只有一个工作线程的线程池,所有任务按顺序执行,保证了任务的顺序性。 3. `newCachedThreadPool()`:创建一个可缓存线程的线程池,如果线程池已满,新任务会等待线程返回,如果在60秒内没有返回,线程将被终止并重新创建。 4. `newScheduledThreadPool(int corePoolSize)`:创建一个定长线程池,支持定时及周期性任务执行。 这些面试知识点涵盖了Java内存管理、数据库理论和并发编程,对于准备Java开发者面试或深化技术理解非常有帮助。