这里会分享各种我觉得不错的面试题以及职场心得。同时,也收录星球中不错的问题讨论,很多讨论放到现在依然可以持续进行,欢迎你的加入!多一点不一样的声音,可能就打开了一种全新的问题解决思路!


Java Core

基本功

  1. 面向对象的特征
  2. final, finally, finalize 的区别
  3. int 和 Integer 有什么区别
  4. 重载和重写的区别
  5. 抽象类和接口有什么区别
  6. 说说反射的用途及实现
  7. 说说自定义注解的场景及实现
  8. HTTP 请求的 GET 与 POST 方式的区别
  9. session 与 cookie 区别
  10. session 分布式处理
  11. JDBC 流程
  12. MVC 设计思想
  13. equals 与 == 的区别

集合

  1. 每日一题:如何确保 List 的线程安全?
  2. 每日一题:HashMap、Hashtable、ConcurrentHashMap 的区别?
  3. List 和 Set 区别
  4. List 和 Map 区别
  5. Arraylist 与 LinkedList 区别
  6. ArrayList 与 Vector 区别
  7. HashSet 和 HashMap 区别
  8. HashMap 和 ConcurrentHashMap 的区别
  9. HashMap 的工作原理及代码实现
  10. ConcurrentHashMap 的工作原理及代码实现

JUC

  1. 每日一题:描述一下 Java 中线程的生命周期?
  2. 每日一题:wait() 方法和 sleep() 方法都能让当前线程挂起一段时间,那它们的区别是什么?
  3. 创建线程的方式及实现
  4. sleep() 、join()、yield()有什么区别
  5. 说说 CountDownLatch 原理
  6. 说说 CyclicBarrier 原理
  7. 说说 Semaphore 原理
  8. 说说 Exchanger 原理
  9. 说说 CountDownLatch 与 CyclicBarrier 区别
  10. ThreadLocal 原理分析
  11. 每日一题:说说线程池的实现原理?
  12. 线程池的几种方式与使用场景
  13. 线程的生命周期
  14. 说说线程安全问题
  15. volatile 实现原理
  16. synchronize 实现原理
  17. synchronized 与 lock 的区别
  18. CAS 乐观锁
  19. ABA 问题
  20. 乐观锁的业务场景及实现方式
  21. 每日一题:一个进程有 3 个线程,如果一个线程抛出 OOM,其他两个线程还能运行吗?
  22. 每日一题:如果想动态修改 Java 线程池的参数,有哪些最佳实践?

数据存储

MySQL

  1. 每日一题:MySQL 索引使用的注意事项?
  2. 每日一题:MySQL 索引的原理?
  3. 每日一题:MySQL 中聚集索引与非聚集索引的区别?
  4. 每日一题:为什么 MySQL 要用 B+树索引,以及B+树索引与 Hash 索引、B 树之间、红黑树的区别?
  5. 每日一题:MySQL 中如果 UUID 作为主键会存在什么问题?
  6. MySQL 如何进行性能优化?
  7. 每日一题:描述一下数据库设计中的反模式?
  8. 每日一题:说说分库与分表设计?
  9. 每日一题:分库与分表带来的分布式困境与应对之策?
  10. 如何设计可以动态扩容的分库分表方案?
  11. 说说 MySQL 的加锁的机制?
  12. 每日一题:描述一下 InnoDB 支持的事务隔离级别?
  13. 每日一题:MySQL 如何解决幻读?
  14. 你是否遇到过 MySQL 死锁问题,描述一下原因和解决方案?
  15. 每日一题:描述一下 MySQL 间歇锁的隔离级别?
  16. 间隙锁如何导致的死锁现象?
  17. MySQL 中 limit 20000 加载很慢,怎么解决?
  18. 如何不停机迁移 MySQL 数据?
  19. 如何实现 MySQL 的读写分离?
  20. 如何实现 MySQL 的主从复制?
  21. MySQL是怎么保证主备一致的?
  22. 每日一题:MySQL 主备延迟由哪些原因导致的?
  23. 如何解决 MySQL 主从同步延时?
  24. 一条SQL查询语句是如何执行的?
  25. 一条SQL更新语句是如何执行的?
  26. 每日一题:MySQL 中 order by 是怎么工作的?
  27. 每日一题:为什么 MySQL 会有 redo log 和 binlog 两份日志呢?
  28. MySQL 中 redo log 一般设置多大?
  29. 每日一题:误删数据后,还能怎么办?
  30. MySQL 什么时候会使用内部临时表?
  31. 在 MySQL 中,会引发性能问题的慢查询,主要有哪几类,如何在紧急情况下,进行优化?

Redis

  1. Redis 有哪些类型
  2. Redis 内部结构
  3. Redis 内存淘汰机制
  4. 聊聊 Redis 使用场景
  5. Redis 持久化机制
  6. Redis 集群方案与实现
  7. Redis 为什么是单线程的
  8. 缓存崩溃
  9. 缓存降级
  10. 使用缓存的合理性问题

MongoDB

ElasticSearch

MQ

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

框架

Spring

  1. BeanFactory 和 ApplicationContext 有什么区别
  2. Spring Bean 的生命周期
  3. Spring IOC 如何实现
  4. 说说 Spring AOP
  5. Spring AOP 实现原理
  6. 动态代理(cglib 与 JDK)
  7. Spring 事务实现方式
  8. Spring 事务底层原理
  9. 如何自定义注解实现功能
  10. Spring MVC 运行流程
  11. Spring MVC 启动流程
  12. Spring 的单例实现原理
  13. Spring 框架中用到了哪些设计模式
  14. Spring 其他产品(Srping Boot、Spring Cloud、Spring Secuirity、Spring Data、Spring AMQP 等)

Netty

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

微服务

  1. 前后端分离是如何做的
  2. 如何解决跨域
  3. 微服务哪些框架
  4. 你怎么理解 RPC 框架
  5. 说说 RPC 的实现原理
  6. 说说 Dubbo 的实现原理
  7. 你怎么理解 RESTful
  8. 说说如何设计一个良好的 API
  9. 如何理解 RESTful API 的幂等性
  10. 如何保证接口的幂等性
  11. 说说 CAP 定理、 BASE 理论
  12. 怎么考虑数据一致性问题
  13. 说说最终一致性的实现方案
  14. 你怎么看待微服务
  15. 微服务与 SOA 的区别
  16. 如何拆分服务
  17. 微服务如何进行数据库管理
  18. 如何应对微服务的链式调用异常
  19. 对于快速追踪与定位问题
  20. 微服务的安全

分布式

  1. 每日一题:分布式全局唯一ID有哪些生成策略?
  2. 每日一题:号段模式如何实现分布式全局唯一ID?
  3. 每日一题:雪花算法如何实现分布式全局唯一ID?
  4. 每日一题:雪花算法的时间时钟问题,如何解决?
  5. 每日一题:订单ID如何生成?
  6. 每日一题:项目中是否使用过延时队列来解决业务需求?
  7. 如何利用RabbitMQ来实现延时队列?
  8. 如何利用时间轮来实现延时队列?
  9. 谈谈业务中使用分布式的场景
  10. Session 分布式方案
  11. 分布式锁的场景
  12. 分布是锁的实现方案
  13. 分布式事务
  14. 集群与负载均衡的算法与实现
  15. 说说分库与分表设计
  16. 分库与分表带来的分布式困境与应对之策

架构

高并发

1. 秒杀系统架构设计都有哪些关键点?

2. 秒杀系统“减库存”设计的核心逻辑?

3. 高并发的场景怎么设计?/ 大流量系统,我们该如何设计?

4. 如何实现高并发环境下的削峰、限流?

高可用

1. 每日一题:高可用系统如何做到99.99%?

业务

安全问题

  1. 安全要素与 STRIDE 威胁
  2. 防范常见的 Web 攻击
  3. 服务端通信安全攻防
  4. HTTPS 原理剖析
  5. HTTPS 降级攻击
  6. 授权与认证
  7. 基于角色的访问控制
  8. 基于数据的访问控制

性能优化

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

需求分析

  1. 你如何对需求原型进行理解和拆分
  2. 说说你对功能性需求的理解
  3. 说说你对非功能性需求的理解
  4. 你针对产品提出哪些交互和改进意见
  5. 你如何理解用户痛点

设计能力

  1. 说说你在项目中使用过的 UML 图
  2. 你如何考虑组件化
  3. 你如何考虑服务化
  4. 你如何进行领域建模
  5. 你如何划分领域边界
  6. 说说你项目中的领域建模
  7. 说说概要设计

设计模式

  1. 你项目中有使用哪些设计模式
  2. 说说常用开源框架中设计模式使用分析
  3. 说说你对设计原则的理解
  4. 23种设计模式的设计理念
  5. 设计模式之间的异同,例如策略模式与状态模式的区别
  6. 设计模式之间的结合,例如策略模式+简单工厂模式的实践
  7. 设计模式的性能,例如单例模式哪种性能更好。

业务工程

  1. 你系统中的前后端分离是如何做的
  2. 说说你的开发流程
  3. 你和团队是如何沟通的
  4. 你如何进行代码评审
  5. 说说你对技术与业务的理解
  6. 说说你在项目中经常遇到的 Exception
  7. 说说你在项目中遇到感觉最难Bug,怎么解决的
  8. 说说你在项目中遇到印象最深困难,怎么解决的
  9. 你觉得你们项目还有哪些不足的地方
  10. 你是否遇到过 CPU 100% ,如何排查与解决
  11. 你是否遇到过 内存 OOM ,如何排查与解决
  12. 说说你对敏捷开发的实践
  13. 说说你对开发运维的实践
  14. 介绍下工作中的一个对自己最有价值的项目,以及在这个过程中的角色

软实力

  1. 说说你的亮点
  2. 说说你最近在看什么书
  3. 说说你觉得最有意义的技术书籍
  4. 说说个人发展方向方面的思考
  5. 说说你认为的服务端开发工程师应该具备哪些能力
  6. 说说你认为的架构师是什么样的,架构师主要做什么
  7. 说说你所理解的技术专家


— 知识星球 —

image.png


— 公众号 —

image.png