Java精选面试题.2020-11-22整理

本文档包含Java面试必备知识点,覆盖基础语法、集合框架、多线程编程、JVM原理、设计模式等内容,帮助读者深入理解Java核心技术。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java精选面试题

目录

Java精选面试题

基础篇

1.Java基础

2.Java常见集合

3.进程和线程

4.锁机制

5.JVM

6.设计模式

7.数据结构

8.网络/IO 基础


基础篇

1.Java基础

1.面向对象的特征

2.final、finally、finalize 的区别

3.Exception、Error、运行时异常与一般异常有何异同

4.java8 大基本类型

5.int 和 integer 的区别,integer 的值缓存范围

6.包装类,装箱和拆箱

7.String、StringBuilder、StringBuffer 区别

8.重载和重写的区别

9.抽象类和接口的区别

10.Http 请求的 get 和 post 方式的区别

11.Session 和 cookie 的区别

12.列出自己常用的 JDK 包

13.MVC 设计思想

14.equals 与==的区别

15.hashcode 与 equals 方法的区别和联系

16.java 的序列化和反序列化,如何实现?Serializable 接口的作用

17.Object 类中常见的方法,为什么 wiat,notify 会放在 Object 里?

18.JDK 和 JRE 的区别

19.Java8 的新特性

20.全局变量和局部变量,分配在什么地方?

21.子类和父类的实例变量和方法有什么区别

22.java 泛型

2.Java常见集合

1.List 和 Set 和 Map 区别

2.ArrayList 和 LinkedList 的区别

3.ArrayList 与 Vector 的区别

4.HashMap 和 Hashtable 的区别

5.HashSet 和 HashMap 的区别

6.HashMap 和 ConcurrentHashMap 的区别

7.HashMap 的工作原理及代码实现,手写简单的 HashMap,处理哈希冲突用的哪种方法?还知道什么处理哈希冲突的方法?什么时候用到红黑树,hashmap 为什么使用红黑树?

8.多线程情况下 HashMap 死循环的问题

9.HashMap 出现 Hash DOS 攻击的问题

10.ConcurrentHashMap 的工作原理及代码实现,如何保证线程安全,如何统计所有的元素个数

11.平衡二叉树判断

12.求单链表倒数第 k 个节点

13.HashMap 的时间复杂度?HashMap 中 Hash 冲突是怎么解决的?链表的上一级结构是什么?

14.Java8 中的 HashMap 有什么变化?红黑树需要比较大小才能进行插入,是依据什么进行比较的?其他 hash 冲突的解决方式?

15.hash 和 B+数的区别?分别应用于什么场景?哪个比较好?

16.看过哪些 Java 集合类的源码

3.进程和线程

1.线程和进程的概念、并行和并发的概念

2.创建线程的方式及实现

3.进程间的通信方式

4.说说 CountDownLatch、CyclicBarrier 的原理和区别

5.说说 Semaphore 的原理

6.说说 Exchanger 的原理

7.ThreadLocal 原理分析、ThreadLocal 为什么会出现 OOM,出现的深层次原理。

8.讲讲线程池的实现原理,线程池的几种实现方式,线程池有哪些?

9.线程的生命周期,状态是如何转移的。

10.多线程有什么用,怎么处理?

11.优先级翻转

12.Handler 和 Looper(单个 Looper 和多个 Handler)Handler 内存泄露,四种引用

13.java 多线程,状态图画出来。阻塞的状态有哪几种?运行顺序。多线程的一些方法?

14.ThreadLocal,Concurrent 下面的包原理是什么

15.AtomicInteger 的原理,如何做到高效率,有什么优化措施。

16.线程池工程有哪些线程池类型及线程池参数是什么?

4.锁机制

1.说说线程安全问题,什么是线程安全,如何保证线程安全

2.重入锁的概念,重入锁为什么可以防止死锁

3.产生死锁的四个条件(互斥、请求与保持、不剥夺、循环等待)

4.如何检查死锁(通过 jConsole 检查死锁)

5.volatile 实现原理(禁止指令重排、刷新内存)

6.synchronized 实现原理(对象监视器)

7.synchronized 与 lock 的区别

8.AQS 同步队列

9.CAS 无锁的概念、乐观锁和悲观锁

10.常见的原子操作类

11.什么是 ABA 问题,出现 ABA 问题 JDK 是如何解决的

12.乐观锁的业务常见及实现方式

13.Java8 并发包下常见的并发类

14.偏向锁、轻量级锁、重量级锁、自旋锁的概念

15.LRU 怎么实现

16.排序中稳定和非稳定

17.快排是稳定还是非稳定

18.乐观锁,悲观锁(selelct for update) 写出 sql 实现

5.JVM

1.JVM 运行时内存区域划分。

2.内存溢出 OOM 和堆栈溢出 SOE 的示例及原因、如何排查与解决

3.如何判断对象是否可以回收或存活

4.常见的 GC 回收算法及其含义

5.常见的 JVM 性能监控和故障处理工具类:jps、jatat、jmap、jinfo、jconsole 等

6.JVM 如何设置参数

7.JVM 性能调优

8.类加载器、双亲委派模型、一个类的生命周期、类是如何加载到 JVM 中的

9.类加载的过程:加载、验证、准备、解析、初始化

10.强引用、软引用、弱引用、虚引用

11.Java 内存模型 JMM

12.堆和栈的区别(内存分配的不同?)

13.Java GC 机制?GC Roots 有哪些?

14.Java 怎么进行垃圾回收的?什么对象会进老年代?垃圾回收算法有哪些?为什么新生代使 用复制算法?

6.设计模式

1.常见的设计模式

2.设计模式的的六大原则及其含义

3.常见的单例模式以及各种实现方式的优缺点,哪一种最好,手写常见的单利模式

4.设计模式在实际场景中的应用

5.Spring 中用到了哪些设计模式

6.MyBatis 中用到了哪些设计模式

7.你项目中有使用哪些设计模式

8.说说常用开源框架中设计模式使用分析

7.数据结构

1.树(二叉查找树、平衡二叉树、红黑树、B 树、B+树)

2.深度有限算法、广度优先算法

3.克鲁斯卡尔算法、普林母算法、迪克拉斯算法

4.什么是一致性 Hash 及其原理、Hash 环问题

5.常见的排序算法和查找算法:快排、折半查找、堆排序等

6.二叉树路径之和为 n

7.数据仓库,雪花模型和星型模型区别和用处,数据仓库的过程(分层),如何设计

8.Top K 问题 0-100 1000w 个小数(后面改成了两位小数)(很详细) -> 桶排序 复杂度

8.网络/IO 基础

1.BIO、NIO、AIO 的概念

2.什么是长连接和短连接

3.Http1.0 和 2.0 相比有什么区别

4.Https 的基本概念

5.三次握手和四次挥手、为什么挥手需要四次 过程是什么?

6.从浏览器中输入 URL 到页面加载的发生了什么?

7.HTTP 和 HTTPS 的区别?在哪层?

8.TCP 和 UDP 的区别,TCP 怎么可靠?

9.TCP 连接和释放

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值