您的位置 首页 java

Java后端架构技术面试汇总:基础+设计模式+MySQL+分布式+微服务等

前言

很多人面试之前,可能没有在互联网公司工作过或者说工作过但年头较短,不知道互联网公司技术面试都会问哪些问题? 再加上可能自己准备也不充分,去面试没几个回合就被面试官几个问题打蒙了,最后以惨败收场。 下述整理的180道 Java 后端常问的面试体系汇总,有整理出一份知识点复习笔记和Java后端高频知识考点专题文档答案免费分享给大家!

一、基础篇

1.1、Java 基础

  1. 面向对象的特征:继承、封装和多态
  2. final, finally, finalize 的区别
  3. Exception、Error、运行时异常与一般异常有何异同
  4. 请写出 5 种常见到的 runtime exception
  5. int 和 Integer 有什么区别,Integer 的值 缓存 范围
  6. 包装类,装箱和拆箱
  7. String、StringBuilder、StringBuffer
  8. 重载和重写的区别
  9. 抽象类和接口有什么区别
  10. 说说反射的用途及实现
  11. 说说自定义注解的场景及实现
  12. HTTP 请求的 GET 与 POST 方式的区别
  13. Session 与 Cookie 区别
  14. 列出自己常用的 JDK
  15. MVC 设计思想
  16. equals 与==的区别
  17. hashCode 和 equals 方法的区别与联系
  18. 什么是 Java 序列化 和反序列化,如何实现 Java 序列化?或者请解释
  19. Serializable 接口的作用
  20. Object 类中常见的方法,为什么 wait notify 会放在 Object 里边?
  21. Java 的平台无关性如何体现出来的
  22. JDK 和 JRE 的区别
  23. Java 8 有哪些新特性

1.2、Java 常见集合

  1. List 和 Set 区别
  2. Set 和 hashCode 以及 equals 方法的联系
  3. List 和 Map 区别
  4. Arraylist 与 LinkedList 区别
  5. ArrayList 与 Vector 区别
  6. HashMap 和 Hashtable 的区别
  7. HashSet 和 HashMap 区别
  8. HashMap 和 ConcurrentHashMap 的区别
  9. HashMap 的工作原理及代码实现,什么时候用到红黑树
  10. 多线程情况下 HashMap 死循环的问题
  11. HashMap 出现 Hash DOS 攻击的问题
  12. ConcurrentHashMap 的工作原理及代码实现,如何统计所有的元素个数
  13. 手写简单的 HashMap
  14. 看过那些 Java 集合类的源码

1.3、进程和线程

  1. 线程和进程的概念、并行和并发的概念
  2. 创建线程的方式及实现
  3. 进程间通信的方式
  4. 说说 CountDownLatch、CyclicBarrier 原理和区别
  5. 说说 Semaphore 原理
  6. 说说 Exchanger 原理
  7. ThreadLocal 原理分析,ThreadLocal 为什么会出现 OOM,出现的深层次原理
  8. 讲讲线程池的实现原理
  9. 线程池的几种实现方式
  10. 线程的生命周期,状态是如何转移的
  11. 可参考:《Java 多线程编程核心技术》

1.4、锁机制

  1. 说说线程安全问题,什么是线程安全,如何保证线程安全
  2. 重入锁的概念,重入锁为什么可以防止 死锁
  3. 产生死锁的四个条件(互斥、请求与保持、不剥夺、循环等待)
  4. 如何检查死锁(通过 jConsole 检查死锁)
  5. volatile 实现原理(禁止指令重排、刷新内存)
  6. synchronized 实现原理(对象监视器)
  7. synchronized 与 lock 的区别
  8. AQS 同步队列
  9. CAS 无锁的概念、乐观锁和悲观锁
  10. 常见的原子操作类
  11. 什么是 ABA 问题,出现 ABA 问题 JDK 是如何解决的
  12. 乐观锁的业务场景及实现方式
  13. Java 8 并法包下常见的并发类
  14. 偏向锁、轻量级锁、重量级锁、自旋锁的概念
  15. 可参考:《Java 多线程编程核心技术》

1.5、JVM

  1. JVM 运行时内存区域划分
  2. 内存溢出 OOM 和堆栈溢出 SOE 的示例及原因、如何排查与解决
  3. 如何判断对象是否可以回收或存活
  4. 常见的 GC 回收算法及其含义
  5. 常见的 JVM 性能监控和故障处理工具类:jps、jstat、jmap、jinfo、jconsole
  6. JVM 如何设置参数
  7. JVM 性能调优
  8. 类加载器、双亲委派模型、一个类的生命周期、类是如何加载到 JVM 中的
  9. 类加载的过程:加载、验证、准备、解析、初始化
  10. 强引用、软引用、弱引用、虚引用
  11. Java 内存模型 JMM

1.6、设计模式

  1. 常见的设计模式
  2. 设计模式的的六大原则及其含义
  3. 常见的单例模式以及各种实现方式的优缺点,哪一种最好,手写常见的单利
  4. 模式
  5. 设计模式在实际场景中的应用
  6. Spring 中用到了哪些设计模式
  7. MyBatis 中用到了哪些设计模式
  8. 你项目中有使用哪些设计模式
  9. 说说常用开源框架中设计模式使用分析
  10. 动态代理很重要!!!

1.7、数据结构

  1. 树(二叉查找树、平衡二叉树、红黑树、B 树、B+树)
  2. 深度有限算法、广度优先算法
  3. 克鲁斯卡尔算法、普林母算法、迪克拉斯算法
  4. 什么是一致性 Hash 及其原理、Hash 环问题
  5. 常见的排序算法和查找算法:快排、折半查找、堆排序等

1.8、网络/IO 基础

  1. BIO、NIO、AIO 的概念
  2. 什么是长连接和短连接
  3. Http1.0 和 2.0 相比有什么区别,可参考《Http 2.0》
  4. Https 的基本概念
  5. 三次握手和四次挥手、为什么挥手需要四次
  6. 从游览器中输入 URL 到页面加载的发生了什么?可参考《从输入 URL 到页
  7. 面加载发生了什么》

二、数据存储和消息队列

2.1、数据库

  1. MySQL 索引 使用的注意事项
  2. DDL、DML、DCL 分别指什么
  3. explain 命令
  4. left join,right join,inner join
  5. 数据库事物 ACID(原子性、一致性、隔离性、持久性)
  6. 事物的隔离级别(读未提交、读以提交、可重复读、可序列化读)
  7. 脏读、幻读、不可重复读
  8. 数据库的几大范式
  9. 数据库常见的命令
  10. 说说分库与分表设计
  11. 分库与分表带来的 分布式 困境与应对之策(如何解决分布式下的分库分表,
  12. 全局表?)
  13. 说说 SQL 优化之道
  14. MySQL 遇到的死锁问题、如何排查与解决
  15. 存储引擎的 InnoDB 与 MyISAM 区别,优缺点,使用场景
  16. 索引类别(B+树索引、全文索引、哈希索引)、索引的原理
  17. 什么是自适应哈希索引(AHI)
  18. 为什么要用 B+tree 作为 MySQL 索引的数据结构
  19. 聚集索引与非聚集索引的区别
  20. 遇到过索引失效的情况没,什么时候可能会出现,如何解决
  21. limit 20000 加载很慢怎么解决
  22. 如何选择合适的分布式主键方案
  23. 选择合适的数据存储方案
  24. 常见的几种分布式 ID 的设计方案
  25. 常见的数据库优化方案,在你的项目中数据库如何进行优化的

2.2、Redis

  1. Redis 有哪些数据类型,可参考《Redis 常见的 5 种不同的数据类型详解》
  2. Redis 内部结构
  3. Redis 使用场景
  4. Redis 持久化机制,可参考《使用快照和 AOF 将 Redis 数据持久化到硬盘
  5. 中》
  6. Redis 集群方案与实现
  7. Redis 为什么是单线程的?
  8. 缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级
  9. 使用缓存的合理性问题
  10. Redis 常见的回收策略

2.3、消息队列

  1. 消息队列的使用场景
  2. 消息的重发补偿解决思路
  3. 消息的幂等性解决思路
  4. 消息的堆积解决思路
  5. 自己如何实现消息队列
  6. 如何保证消息的有序性

三、开源框架和容器

3.1、SSM/ Servlet

  1. Servlet 的生命周期
  2. 转发与重定向的区别
  3. BeanFactory 和 ApplicationContext 有什么区别
  4. Spring Bean 的生命周期
  5. Spring IOC 如何实现
  6. Spring 中 Bean 的作用域,默认的是哪一个
  7. 说说 Spring AOP、Spring AOP 实现原理
  8. 动态代理(CGLib 与 JDK)、优缺点、性能对比、如何选择
  9. Spring 事务实现方式、事务的传播机制、默认的事务类别
  10. Spring 事务底层原理
  11. Spring 事务失效(事务嵌套),JDK 动态代理给 Spring 事务埋下的坑,可
  12. 参考《JDK 动态代理给 Spring 事务埋下的坑!》
  13. 如何自定义注解实现功能
  14. 运行流程
  15. 启动流程
  16. spring 的单例实现原理
  17. spring 框架中用到了哪些设计模式
  18. Spring 其他产品(Srping Boot、Spring Cloud、Spring Secuirity、Spring Data、Spring AMQP 等)
  19. 有没有用到 Spring Boot,Spring Boot 的认识、原理
  20. MyBatis 的原理
  21. 可参考《为什么会有 Spring》
  22. 可参考《为什么会有 Spring AOP》

3.2、 Netty

  1. 为什么选择 Netty
  2. 说说业务中,Netty 的使用场景
  3. 原生的 NIO 在 JDK 1.7 版本存在 epoll bug
  4. 什么是 TCP 粘包/拆包
  5. TCP 粘包/拆包的解决办法
  6. Netty 线程模型
  7. 说说 Netty 的零拷贝
  8. Netty 内部执行流程
  9. Netty 重连实现

3.3、 Tomcat

  1. Tomcat 的基础架构(Server、Service、Connector、Container)
  2. Tomcat 如何加载 Servlet 的
  3. Pipeline-Valve 机制
  4. 可参考:《四张图带你了解 Tomcat 系统架构!》

四、分布式

4.1、 Nginx

  1. 请解释什么是 C10K 问题或者知道什么是 C10K 问题吗?
  2. Nginx 简介,可参考《Nginx 简介》
  3. 正向代理和反向代理.
  4. Nginx 几种常见的负载均衡策略
  5. Nginx 服务器上的 Master 和 Worker 进程分别是什么
  6. 使用“反向代理服务器”的优点是什么?

4.2、分布式其他

  1. 谈谈业务中使用分布式的场景
  2. Session 分布式方案
  3. Session 分布式处理
  4. 分布式锁的应用场景、分布式锁的产生原因、基本概念
  5. 分布是锁的常见解决方案
  6. 分布式事务的常见解决方案
  7. 集群与负载均衡的算法与实现
  8. 说说分库与分表设计,可参考《数据库分库分表策略的具体实现方案》
  9. 分库与分表带来的分布式困境与应对之策

4.3、 Dubbo

  1. 什么是 Dubbo,可参考《Dubbo 入门》
  2. 什么是 RPC 、如何实现 RPC、RPC 的实现原理,可参考《基于 HTTP 的
  3. RPC 实现》
  4. Dubbo 中的 SPI 是什么概念
  5. Dubbo 的基本原理、执行流程

五、 微服务

5.1、微服务

  1. 前后端分离是如何做的?
  2. 微服务哪些框架
  3. Spring Could 的常见组件有哪些?可参考《Spring Cloud 概述》
  4. 领域驱动有了解吗?什么是领域驱动模型?充血模型、贫血模型
  5. JWT 有了解吗,什么是 JWT,可参考《前后端分离利器之 JWT》
  6. 你怎么理解 RESTful
  7. 说说如何设计一个良好的 API
  8. 如何理解 RESTful API 的幂等性
  9. 如何保证接口的幂等性
  10. 说说 CAP 定理、BASE 理论
  11. 怎么考虑数据一致性问题
  12. 说说最终一致性的实现方案
  13. 微服务的优缺点,可参考《微服务批判》
  14. 微服务与 SOA 的区别
  15. 如何拆分服务、水平分割、垂直分割
  16. 如何应对微服务的链式调用异常
  17. 如何快速追踪与定位问题
  18. 如何保证微服务的安全、认证

5.2、安全问题

  1. 如何防范常见的 Web 攻击、如何方式 SQL 注入
  2. 服务端通信安全攻防
  3. HTTPS 原理剖析、降级攻击、HTTP 与 HTTPS 的对比

5.3、性能优化

  1. 性能指标有哪些
  2. 如何发现性能瓶颈
  3. 性能调优的常见手段
  4. 说说你在项目中如何进行性能调优

六、其他

6.1、设计能力

  1. 说说你在项目中使用过的 UML 图
  2. 你如何考虑组件化、服务化、系统拆分
  3. 秒杀场景如何设计
  4. 可参考:《秒杀系统的技术挑战、应对策略以及架构设计总结一二!》

6.2、业务工程

  1. 说说你的开发流程、如何进行自动化部署的
  2. 你和团队是如何沟通的
  3. 你如何进行代码评审
  4. 说说你对技术与业务的理解
  5. 说说你在项目中遇到感觉最难 Bug,是如何解决的
  6. 介绍一下工作中的一个你认为最有价值的项目,以及在这个过程中的角色、 解决的问题、你觉得你们项目还有哪些不足的地方

6.3、软实力

  1. 说说你的优缺点、亮点
  2. 说说你最近在看什么书、什么博客、在研究什么新技术、再看那些开源项目 的源代码
  3. 说说你觉得最有意义的技术书籍
  4. 工作之余做什么事情、平时是如何学习的,怎样提升自己的能力
  5. 说说个人发展方向方面的思考
  6. 说说你认为的服务端开发工程师应该具备哪些能力
  7. 说说你认为的架构师是什么样的,架构师主要做什么
  8. 如何看待加班的问题

答案笔记免费分享

由于篇幅原因,在这只把部分的题目列举出来,答案就不做全部展示了,这些题我已经整理成pdf文档免费分享给那些有需要的朋友,同时整理也花费了蛮多时间, 有需要的朋友可以帮忙转发分享下然后关注我私信关键词【面试】即可获取免费领取方式!

文章来源:智云一二三科技

文章标题:Java后端架构技术面试汇总:基础+设计模式+MySQL+分布式+微服务等

文章地址:https://www.zhihuclub.com/197881.shtml

关于作者: 智云科技

热门文章

网站地图