Java面试题总结(附答案),面试答题案例

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

1、java 容器都有哪些?

2、Collection 和 Collections 有什么区别?

3、List、Set、Map 之间的区别是什么?

4、HashMap 和 Hashtable 有什么区别?

5、说一下 HashMap 的实现原理?

6、set有哪些实现类?

7、说一下 HashSet 的实现原理?

8、ArrayList 和 LinkedList 的区别是什么?

9、如何实现数组和 List 之间的转换?

10、ArrayList 和 Vector 的区别是什么?

11、Array 和 ArrayList 有何区别?

12、在 Queue 中 poll()和 remove()有什么区别?

13、哪些集合类是线程安全的?

14、迭代器 Iterator 是什么?

15、Iterator 怎么使用?有什么特点?

16、Iterator 和 ListIterator 有什么区别?

17、怎么确保一个集合不能被修改?

18、队列和栈是什么?有什么区别?

三、多线程


1、Synchronized 用过吗,其原理是什么?

2、请对比下 volatile 对比 Synchronized 的异同。

3、请谈谈 volatile 有什么特点,为什么它能保证变量对所有线程的可见性?

4、JVM 对 Java 的原生锁做了哪些优化?

5、为什么说 Synchronized 是非公平锁?

6、什么是锁消除和锁粗化?

7、为什么说 Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是 CAS,它有什么特性?

8、乐观锁一定就是好的吗?

9、跟 Synchronized 相比,可重入锁 ReentrantLock 其实现原理有什么不同?

10、那么请谈谈 AQS 框架是怎么回事儿?

11、请尽可能详尽地对比下 Synchronized 和 ReentrantLock 的异同。

12、ReentrantLock 是如何实现可重入性的?

13、除了 ReetrantLock,你还接触过 JUC 中的哪些并发工具?

14、请谈谈 ReadWriteLock 和 StampedLock。

15、如何让 Java 的线程彼此同步?你了解过哪些同步器?请分别介绍下。

16、CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢?

17、Java 线程池相关问题

18、Java 中的线程池是如何实现的?

19、创建线程池的几个核心构造参数?

20、线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?

21、既然提到可以通过配置不同参数创建出不同的线程池,那么 Java 中默认实现好的线程池又有哪些呢?请比较它们的异同

22、如何在 Java 线程池中提交线程?

23、什么是 Java 的内存模型,Java 中各个线程是怎么彼此看到对方的变量的?

24、ThreadLocal 是什么?有哪些使用场景?

25、既然 volatile 能够保证线程间的变量可见性,是不是就意味着基于 volatile 变量的运算就是并发安全的?

26、Java8开始ConcurrentHashMap,为什么舍弃分段锁?

27、请谈谈 ThreadLocal 是怎么解决并发安全的?

28、很多人都说要慎用 ThreadLocal,谈谈你的理解,使用 ThreadLocal 需要注意些什么?

29、什么是上下文切换?

30、线程的run()和start()有什么区别?

31、为什么我们调用 start() 方法时会执行 run() 方法,为什么我们不能直接调用 run() 方法?

32、什么是线程调度器(Thread Scheduler)和时间分片(Time Slicing )?

33、为什么 wait(), notify()和 notifyAll()必须在同步方法或者同步块中被调用?

34、Thread 类中的 yield 方法有什么作用?

35、Java 如何实现多线程之间的通讯和协作?

36、为什么代码会重排序?

37、什么是自旋

38、多线程中 synchronized 锁升级的原理是什么?

39、synchronized 和 ReentrantLock 区别是什么?

40、volatile 关键字的作用

41、Java Concurrency API 中的 Lock 接口(Lock interface)是什么?对比同步它有什么优势?

42、AQS是什么?

43、AQS 对资源的共享方式?

四、Java Web


1、jsp 和 servlet 有什么区别?

2、jsp 有哪些内置对象?作用分别是什么?

3、说一下 jsp 的 4 种作用域?

4、session 和 cookie 有什么区别?

5、说一下 session 的工作原理?

6、如果客户端禁止 cookie 能实现 session 还能用吗?

7、spring mvc 和 struts 的区别是什么?

8、如何避免 sql 注入?

9、什么是 XSS 攻击,如何避免?

10、什么是 CSRF 攻击,如何避免?

五、网络


1、http 响应码 301 和 302 代表的是什么?有什么区别?

2、forward 和 redirect 的区别?

3、简述 tcp 和 udp的区别?

4、tcp 为什么要三次握手,两次不行吗?为什么?

5、说一下 tcp 粘包是怎么产生的?

6、OSI 的七层模型都有哪些?

7、get 和 post 请求有哪些区别?

8、如何实现跨域?

9、说一下 JSONP 实现原理?

六、设计模式


1、请列举出在 JDK 中几个常用的设计模式?

2、什么是设计模式?你是否在你的代码里面使用过任何设计模式?

3、Java 中什么叫单例设计模式?请用 Java 写出线程安全的单例模式

4、在 Java 中,什么叫观察者设计模式(observer design pattern)?

5、使用工厂模式最主要的好处是什么?在哪里使用?

6、举一个用 Java 实现的装饰模式(decorator design pattern)?它是作用于对象层次还是类层次?

7、在 Java 中,为什么不允许从静态方法中访问非静态变量?

8、设计一个 ATM 机,请说出你的设计思路?

9、在 Java 中,什么时候用重载,什么时候用重写?

10、举例说明什么情况下会更倾向于使用抽象类而不是接口

七、Spring/SpringMVC


1、什么是 Spring 框架?Spring 框架有哪些主要模块?

2、使用 Spring 框架能带来哪些好处?

3、什么是控制反转(IOC)?什么是依赖注入?

4、请解释下 Spring 框架中的 IoC?

5、BeanFactory 和 ApplicationContext 有什么区别?

6、Spring 有几种配置方式?

7、请解释 Spring Bean 的生命周期?

8、Spring Bean 的作用域之间有什么区别?

9、什么是 Spring inner beans?

10、Spring 框架中的单例 Beans 是线程安全的么?

11、请举例说明如何在 Spring 中注入一个 Java Collection?

12、如何向 Spring Bean 中注入一个 Java.util.Properties?

13、请解释 Spring Bean 的自动装配?

14、请解释自动装配模式的区别?

15、如何开启基于注解的自动装配?

16、请举例解释@Required 注解?

17、请举例解释@Autowired 注解?

18、请举例说明@Qualifier 注解?

19、构造方法注入和设值注入有什么区别?

20、Spring 框架中有哪些不同类型的事件?

21、FileSystemResource 和 ClassPathResource 有何区别?

22、Spring 框架中都用到了哪些设计模式?

八、Spring Boot/Spring Cloud


1、什么是 Spring Boot?

2、Spring Boot 有哪些优点?

3、什么是 JavaConfig?

5、Spring Boot 中的监视器是什么?

6、如何在 Spring Boot 中禁用 Actuator 端点安全性?

7、如何在自定义端口上运行 Spring Boot 应用程序?

8、什么是 YAML?

9、如何实现 Spring Boot 应用程序的安全性?

10、如何集成 Spring Boot 和 ActiveMQ?

11、如何使用 Spring Boot 实现分页和排序?

12、什么是 Swagger?你用 Spring Boot 实现了它吗?

13、什么是 Spring Profiles?

14、什么是 Spring Batch?

15、什么是 FreeMarker 模板?

16、如何使用 Spring Boot 实现异常处理?

17、您使用了哪些 starter maven 依赖项?

18、什么是 CSRF 攻击?

19、什么是 WebSockets?

20、什么是 AOP?

21、什么是 Apache Kafka?

22、我们如何监视所有 Spring Boot 微服务?

23、什么是 spring cloud?

24、spring cloud 断路器的作用是什么?

26、spring cloud 的核心组件有哪些?

九、Hibernate


1、为什么要使用 hibernate?

2、什么是 ORM 框架?

3、hibernate 中如何在控制台查看打印的 sql 语句?

4、hibernate 有几种查询方式?

5、hibernate 实体类可以被定义为 final 吗?

6、在 hibernate 中使用 Integer 和 int 做映射有什么区别?

7、hibernate 是如何工作的?

8、get()和 load()的区别?

9、说一下 hibernate 的缓存机制?

10、hibernate 对象有哪些状态?

11、在 hibernate 中 getCurrentSession 和 openSession 的区别是什么?

12、hibernate 实体类必须要有无参构造函数吗?为什么?

十、MyBatis


1、mybatis 中 #{}和 ${}的区别是什么?

2、mybatis 有几种分页方式?

3、RowBounds 是一次性查询全部结果吗?为什么?

4、mybatis 逻辑分页和物理分页的区别是什么?

5、mybatis 是否支持延迟加载?延迟加载的原理是什么?

6、说一下 mybatis 的一级缓存和二级缓存?

7、mybatis 和 hibernate 的区别有哪些?

8、mybatis 有哪些执行器(Executor)?

9、mybatis 分页插件的实现原理是什么?

10、mybatis 如何编写一个自定义插件?

十一、RabbitMQ


1、RabbitMQ的使用场景有哪些?

2、RabbitMQ有哪些重要的角色?

3、RabbitMQ有哪些重要的组件?

4、RabbitMQ中 vhost 的作用是什么?

5、RabbitMQ的消息是怎么发送的?

6、RabbitMQ怎么保证消息的稳定性?

7、RabbitMQ怎么避免消息丢失?

8、要保证消息持久化成功的条件有哪些?

9、RabbitMQ持久化有什么缺点?

10、RabbitMQ有几种广播类型?

11、RabbitMQ怎么实现延迟消息队列?

12、RabbitMQ集群有什么用?

13、RabbitMQ节点的类型有哪些?

14、RabbitMQ集群搭建需要注意哪些问题?

15、RabbitMQ每个节点是其他节点的完整拷贝吗?为什么?

16、RabbitMQ集群中唯一一个磁盘节点崩溃了会发生什么情况?

17、RabbitMQ对集群节点停止顺序有要求吗?

十二 、Kafka(未掌握,暂时不做)


  1. 如何获取 topic 主题的列表

  2. 生产者和消费者的命令行是什么?

  3. consumer是推还是拉?

  4. 讲讲kafka维护消费状态跟踪的方法

  5. 讲一下主从同步

  6. 为什么需要消息系统,mysql 不能满足需求吗?

  7. Zookeeper 对于 Kafka 的作用是什么?

  8. 数据传输的事务定义有哪三种?

  9. Kafka 判断一个节点是否还活着有那两个条件?

  10. Kafka 与传统 MQ 消息系统之间有三个关键区别

  11. 讲一讲 kafka 的 ack 的三种机制

  12. 消费者如何不自动提交偏移量,由应用提交?

  13. 消费者故障,出现活锁问题如何解决?

  14. 如何控制消费的位置

  15. kafka分布式(不是单机)的情况下,如何保证消息的顺序消费?

  16. kafka的高可用机制是什么?

  17. kafka如何减少数据丢失

  18. kafka如何不消费重复数据?比如扣款,我们不能重复的扣。

十三、Zookeeper(未掌握,暂时不做)


  1. ZooKeeper 提供了什么?

  2. Zookeeper 文件系统

  3. ZAB 协议?

  4. 四种类型的数据节点 Znode

  5. Zookeeper Watcher 机制 – 数据变更通知

  6. 客户端注册 Watcher 实现

  7. 服务端处理 Watcher 实现

  8. 客户端回调 Watcher

  9. ACL 权限控制机制

  10. Chroot 特性

  11. 会话管理

  12. 服务器角色

  13. Zookeeper 下 Server 工作状态

  14. 数据同步

  15. zookeeper 是如何保证事务的顺序一致性的?

  16. 分布式集群中为什么会有 Master?

  17. zk 节点宕机如何处理?

  18. zookeeper 负载均衡和 nginx 负载均衡区别

  19. Zookeeper 有哪几种几种部署模式?

  20. 集群最少要几台机器,集群规则是怎样的?

  21. 集群支持动态添加机器吗?

  22. Zookeeper 对节点的 watch监听通知是永久的吗?为什么不是永久的?

  23. Zookeeper 的 java 客户端都有哪些?

  24. chubby 是什么,和 zookeeper 比你怎么看?

  25. 说几个 zookeeper 常用的命令。

  26. ZAB 和 Paxos 算法的联系与区别?

  27. Zookeeper 的典型应用场景

十四、MySql


1、数据库的三范式是什么?

2、一张自增表里面总共有 7 条数据,删除了最后 2 条数据,重启 mysql 数据库,又插入了一条数据,此时 id 是几?

3、如何获取当前数据库版本?

4、说一下 ACID 是什么?

5、char 和 varchar 的区别是什么?

6、float 和 double 的区别是什么?

7、mysql 的内连接、左连接、右连接有什么区别?

8、mysql 索引是怎么实现的?

9、怎么验证 mysql 的索引是否满足需求?

10、说一下数据库的事务隔离?

11、说一下 mysql 常用的引擎?

12、说一下 mysql 的行锁和表锁?

13、说一下乐观锁和悲观锁?

14、mysql 问题排查都有哪些手段?

15、如何做 mysql 的性能优化?

十五、Redis


1、Redis是什么?都有哪些使用场景?

2、Redis有哪些功能?

3、Redis和 memecache 有什么区别?

4、Redis为什么是单线程的?

5、什么是缓存穿透?怎么解决?

6、Redis支持的数据类型有哪些?

7、Redis支持的 java 客户端都有哪些?

8、jedis 和 redisson 有哪些区别?

9、怎么保证缓存和数据库数据的一致性?

10、Redis持久化有几种方式?

11、Redis怎么实现分布式锁?

12、Redis分布式锁有什么缺陷?

13、Redis如何做内存优化?

14、Redis淘汰策略有哪些?

15、Redis常见的性能问题有哪些?该如何解决?

十六、JVM


读者福利

分享一份自己整理好的Java面试手册,还有一些面试题pdf

不要停下自己学习的脚步

字节跳动的面试分享,为了拿下这个offer鬼知道我经历了什么

字节跳动的面试分享,为了拿下这个offer鬼知道我经历了什么

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
客户端都有哪些?

8、jedis 和 redisson 有哪些区别?

9、怎么保证缓存和数据库数据的一致性?

10、Redis持久化有几种方式?

11、Redis怎么实现分布式锁?

12、Redis分布式锁有什么缺陷?

13、Redis如何做内存优化?

14、Redis淘汰策略有哪些?

15、Redis常见的性能问题有哪些?该如何解决?

十六、JVM


读者福利

分享一份自己整理好的Java面试手册,还有一些面试题pdf

不要停下自己学习的脚步

[外链图片转存中…(img-A2bOXUQH-1713263203951)]

[外链图片转存中…(img-jaPX3yfr-1713263203951)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-rLupheks-1713263203952)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值