写点什么

2021Java 高级面试题总结:docker 运行 jar 包依赖和程序分开

发布于: 2021 年 07 月 31 日

1. Redis 面试专题

绝大部分写业务的程序员,在实际开发中使用 Redis 的时候,只会 Set Value 和 Get Value 两个操作,对 Redis 整体缺乏一个认知。这里以面试题的形式对 Redis 常见问题做一个总结,解决大家的知识盲点。


  1. 什么是 Redis?简述它的优缺点?

  2. 为什么要用 redis /为什么要用缓存

  3. 为什么要用 redis 而不用 map/guava 做缓存?

  4. redis 和 memcached 的区别

  5. 讲一下 redis 常见数据结构以及使用场景分析

  6. redis 怎么设置过期时间

  7. 解释一下 redis 内存淘汰机制(MySQL 里有 2000w 数据,Redis 中只存 20w 的数据,如何保证 Redis 中的数据都是热点数据?)

  8. 如何应对缓存穿透和缓存雪崩问题

  9. 说一下 redis 事务

  10. Redis 常见异常及解决方案

  11. 讲讲分布式环境下常见的应用场景

  12. 讲讲 Redis 集群模式

  13. 如何解决 Redis 的并发竞争 Key 问题

  14. 如何保证缓存与数据库双写时的数据一致性?

  15. 说一下 redis 持久化机制(怎么保证 redis 挂掉之后再重启数据可以进行恢复)

  16. 单线程的 Redis 为什么这么快

1.1 Redis 学习面试资料


1.2 Redis 学习路线思维导图

数据库面试专题

随着工作经验的积累,我日益感觉到,对一名程序员来说,拥有良好的数据库设计能力是很重要的,甚至是最重要的。这里以面试题的形式对数据库常见问题做一个总结,解决大家的知识盲点。


  1. 请简洁描述 MySQL 中 InnoDB 支持的四种事务隔离级别名称,以及逐级之间的区别?

  2. 在 MySQL 中 ENUM 的用法是什么?

  3. MySQL 数据库服务器性能分析的方法命令有哪些?

  4. MySQL 中使用什么存储引擎?

  5. 详细说说事务四大特性(ACID)原子性、一致性、隔离 性、持久性?

  6. 什么是事务的并发?事务隔离级别,每个级别会引发 什么问题,MySQL 默认是哪个级别?

  7. MySQL 常见的三种存储引擎(InnoDB、 MyISAM、MEMORY)的区别?

  8. MySQL 存储引擎 MyISAM 与 InnoDB 如何选择

  9. MySQL B+Tree 索引和 Hash 索引的区别?

  10. 什么是临时表,临时表什么时候删除?

  11. MySQL B+Tree 索引和 Hash 索引的区别?

  12. sql 查询语句确定创建哪种类型的索引,如何优 化查询

  13. 有哪些锁(乐观锁悲观锁),select 时怎么加 排它锁?

  14. 什么样的字段适合建索引

  15. MySQL 的 MyISAM 与 InnoDB 两种存储引擎在,事务、锁级别,各自的适用场景?

2.1 数据库学习面试资料


2.2 数据库学习路线思维导图

3. 多线程/高并发面试专题

对于并发与多线程的处理,是一个优秀的技术工程师成长过程中必须攻下的难关。它贯穿着日常工作,也是入职面试重点考察的重点。这里以面试题的形式对多线程常见问题做一个总结,解决大家的知识盲点。


  1. stop() 和 suspend() 方法为何不推荐使用?

  2. sleep() 和 wait() 有什么区别?

  3. 同步和异步有何异同,在什么情况下分别使用他们?

  4. 当一个线程进入一个对象的一个 synchronized 方法后,其它线程是否可进入此对象的其它方法?

  5. 简述 synchronized 和 java.util.concurrent.locks.Lock 的异同?

  6. 什么是 ThreadLocal?

  7. run() 和 start() 区别。

  8. 请说出你所知道的线程同步的方法。

  9. 线程调度和线程控制。

  10. 什么是线程饿死,什么是活锁?

  11. 多线程中的忙循环是什么?

  12. volatile 变量是什么?volatile 变量和 atomic 变量有什么不同?

  13. volatile 类型变量提供什么保证?能使得一个非原子操作变成原子操作吗?

  14. 普通线程与守护线程?

  15. 线程饥饿与活锁?

3.1 多线程/高并发学习面试资料


3.2 多线程/高并发学习路线思维导图

4. 性能优化专题

从基础代码,到 JVM 深度调优、设计模式优化、数据库调优、并发编程性能优化、Tomcat 调优、MySQL 性能优化,让一切幻象不攻自破!


4.1 JVM 相关面试题


  1. 什么是 JVM?

  2. 类加载器是如何加载 class 文件的?

  3. 双亲委派模型(Parent Delegation Model)?

  4. 垃圾回收算法有哪些?

  5. GC 什么时候开始?

  6. JVM 内存分哪几个区,每个区的作用是什么?


4.2 Tomcat 面试专题


  1. Tomcat 如何优化?

  2. 内存调优

  3. 垃圾回收策略调优

  4. 共享 session 处理

  5. 关于 Tomcat 的 session 数目

  6. 监视 Tomcat 的内存使用情况

  7. Tomcat 工作模式?


4.3 SQL 优化面试专题


  1. 数据库的读写分离、主从复制,主从复制分析?

  2. MySQL 慢查询怎么解决?

  3. 使用 explain 优化 sql 和索引?

  4. 数据库崩溃时事务的恢复机制(REDO 日志和 UNDO 日志)?

  5. MySQL 高并发环境解决方案?

4.4 性能优化学习面试资料


4.4 性能优化学习路线思维导图

5. 分布式专题

分布式分为分布式缓存(Redis)、分布式锁(Redis 或 Zookeeper)、分布式服务(Dubbo 或 SpringCloud)、分布式服务协调(Zookeeper)、分布式消息队列(Kafka、RabbitMq)、分布式 Session、分布式事务、分布式搜索(elastaticSearch)等;这里以面试题的形式对分布式常见问题做一个总结,解决大家的知识盲点。


  1. 分布式有哪些理论?

  2. 你怎么理解分布式一致性?

  3. 你怎么理解分布式事务?分布式事务的协议有哪些?

  4. 分布式事务的解决方案有哪些?

  5. 怎么保证分布式系统的幂等性?

  6. Redis 如何实现分布式锁?

  7. Redis 采用多主多从的集群模式,各个主节点的数据是否一致?

  8. 缓存雪崩是什么?怎么解决缓存雪崩?

  9. 缓存穿透是什么?怎么解决缓存穿透?

  10. Zookeeper 的原理是什么?

  11. Zookeeper 有哪些应用场景?

  12. Zookeeper 的节点有哪些类型?有什么区别?

  13. Zookeeper 为什么能做注册中心?

  14. Zookeeper 是怎么实现分布式锁的?

  15. 讲一下 Zookeeper 的读写机制。Zookeeper 是怎么保持一致性的?

5.1 分布式学习面试资料

5.2 分布式面试专题系列:缓存+限流+通讯


最后

针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。


最新整理面试题


上述的面试题答案都整理成文档笔记。也还整理了一些面试资料 &最新 2021 收集的一些大厂的面试真题,有需要的可以点击这里,免费获取


最新整理电子书



最新整理大厂面试文档



以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

用户头像

VX:vip204888 领取资料 2021.07.29 加入

还未添加个人简介

评论

发布
暂无评论
2021Java高级面试题总结:docker运行jar包依赖和程序分开