8

前言

我做Java也十来年了,现在也算是中层管理,每次招聘都需要找一些面试题,干脆自己整理了一份,这份面试宝典是从我 去年开始收集的,一方面是给公司招聘用,另一方面也是想用它,来挖掘自己在 Java 技术栈中,还有那些知识点我了解的不够,然后再去复习一遍,以此来提高自己的技术深度,也增加一下自己的技术广度。

然后说回面试的事,这份面试宝典本来是只有我们内部使用的,可到后来有很多朋友在微信上联系到我,让我帮他们找一些面试方面的资料,而且这些关系也不太好拒绝,到最后我干脆就有了这么一个想法,要不要把我整理的这面试宝典,去帮助更多的人。于是我就花了两天时间把面试宝典重新优化整理了一下放在了下面:

面试题模块介绍

说了这么多,下面进入我们本文的主题,我们这份面试题,包含的内容了十九了模块:Java 基础、容器、多线程、反射、对象拷贝、Java Web 模块、异常、网络、设计模式、Spring/Spring MVC、Spring Boot/Spring Cloud、Hibernate、Mybatis、RabbitMQ、Kafka、Zookeeper、MySql、Redis、JVM 。如下图所示:


适宜阅读人群

需要面试的初/中/高级 java 程序员

想要查漏补缺的人

想要不断完善和扩充自己 java 技术栈的人

下面一起来看这份面试宝典,具体的内容。

JVM:

  1. 【高频】Java内存区域   :

{ 程序计数器 , 虚拟机栈 ,本地方法栈 , 堆 ,方法区 ,元空间 }    // 每个区域要能介绍一下

2.    Minor GC 触发条件 :  eden区剩余内存是否足够 两种情况分开分析

FULL GC  触发条件 : Minor GC 平均晋升空间大小 > 老年代连续剩余空间,则触发FULL GC

  1. 【高频】 判断对象死亡的方法 : { 引用计数法 ,可达分析算法 }

深入一些,:GC root对象有哪些?为什么选择他们做GC root对象

4.    垃圾收集算法  : { 标记清除算法 、标记整理算法 、 复制算法、 分代收集算法 }

深入一些: 各个算法的优点和适用场景

5.   垃圾收集器 : { serial  、 parallel 、 CMS 、 G1  }

CMS 、G1 重点 , 介绍工作流程和优缺点

6.    内存泄漏

例子: { 单例 , 容器 等等}

原因 : 长生命周期持有短生命周期引用

7.   引用类型 ; {  强引用、 软引用、 弱引用 、 虚引用  }

  1. 【高频】  类加载过程 : { 加载 , 连接 , 初始化 }

有哪些类加载器 , 能否自定义 Java.Object.String 的类加载器 ?

  1. 【高频】 双亲委派机制 介绍 & 作用

JVM面试题及答案

spring :

  1. 什么是Spring框架?Spring框架有哪些主要模块?
  2. 使用Spring框架有什么好处?
  3. 什么是控制反转(IOC)?什么是依赖注入?
  4. 请解释下Spring中的IOC?
  5. BeanFactory和ApplicationContext有什么区别?
  6. 将Spring配置到你的应用中共有几种方法?
  7. 什么基于XML的配置?
  8. 什么基Java的配置?
  9. 怎样用注解的方式配置Spring?
  10. 描述Spring Bean的生命周期?
  11. 描述Spring中各种Bean的范围?
  12. 什么是Spring的嵌入beans?
  13. Spring框架中的单例bean是否是线程安全的?
  14. 请举例说明如何用Spring注入一个Java的集合类?
  15. 请举例说明如何在Spring的Bean中注入一个java.util.Properties?
  16. 请解释Spring的Bean的自动生成原理?
  17. 请辨析自动生成Bean之间模块的区别?
  18. 如何开启基于基于注解的自动写入?
  19. 请举例说明@Required注解?
  20. 请举例说明@Autowired注解?
  21. 请举例说明@Qualifier注解?
  22. 请说明构造器注入和setter方法注入之间的区别?
  23. Spring框架中不同类型event有什么区别?
  24. FileSystemResource和ClassPathResource有何区别?
  25. 请列举Spring框架中用了哪些设计模式?

spring面试专题及答案

并发 :

1.   线程的状态 : { new ,runnalbe , wait , time-wait , block , terminated }

2.  进程 、 线程 、 协程 的含义和区别      // 个人理解 是一组渐进提出的概念

3.  进程间通信方式 : {  管道 、FIFO 、 信号量 、 共享内存 、 消息队列 、 Socket  } 

4.   如何避免死锁 ? 死锁的四个必要条件 

5.   Sleep和wait的区别 

  1.   【高频】Sychronized 和 lock 的区别 ?
  2. Sychronized的底层优化 : { 无锁、偏向锁、轻量级锁 、重量级锁 }

8.    volatile的作用 : { 指令重拍 、 保证变量的可见性(设计JMM)} 

9.   ThreadLocal 底层原理

10. 【高频】 线程池

线程池构造器涉及哪些参数 : { corePoolSize , maximumPoolSzie , timeout , timeUnit , RejectHandler , 等待队列 , 线程工厂 }
介绍线程池工作过程?
线程池拒绝策略那些?
适用Executor创建线程池的弊端?
11.    AQS 框架原理和 源码理解

并发面试专题及答案

MySQL:

1.   【高频】MyISAM 和 InnoDB的区别    : {是否支持行锁 、 是否支持十五 、 是否支持 MVCC 、 底层索引结构不同 }

2.   事务特性ACID
深入一些 : 为什么要有一致性 ? AID不是已经保证了一致性了吗 ? 

3.   并发事务带来的问题 : {    脏读 、 修改丢失 、 不可重复读 、 幻影读    }

  1. 【高频】事务的隔离级别 

5 【高频】 MVCC机制

6 .  【高频】索引
为什么索引使用B+树结构,而不是B树
为什么索引使用B+树结构,而不是红黑树 : {  磁盘预读取 、红黑树高度 }

7.    聚簇索引和非聚簇索引区别? 主键索引和二级索引了解吗?

8 .    为什么不对每个列创建索引呢?

9     【高频】SQL语句优化 ,SQL题目(字节要求撸代码)

10.    explain中 rows type key extra字段的含义?

11.    count(1) count(*) count(列值)的区别

mysql面试专题及答案

Redis

1.什么是Redis
2.Redis有哪些优缺点
3.为什么要用 Redis /为什么要用缓存
4.为什么要用 Redis 而不用 map/guava 做缓存?
5.Redis为什么这么快
6.Redis有哪些数据类型
7.Redis的应用场景
8.什么是Redis持久化?
9.Redis 的持久化机制是什么?各自的优缺点?
10.如何选择合适的持久化方式
11.Redis持久化数据和缓存怎么做扩容?
12.过期键的删除策略
13.Redis的过期键的删除策略
14.Redis key的过期时间和永久有效分别怎么设置?
15.我们知道通过expire来设置key 的过期时间,那么对过期的数据怎么处理呢?

redis面试专题及答案

其他:面试题以及答案我都已经整理成了笔记,想获取这份面试宝典的可以关注公众号:前程有光,后台回复领取资料即可获取资料


前程有光
936 声望618 粉丝