一、Java基础知识
1.集合相关知识
HashMap、LinkedHashMap、ConcurrentHashMap、ArrayList、LinkedList的底层实现。
ArrayList和LinkList的区别。
HashMap,HashTable和ConcurrentHashMap的区别。
ConcurrentHashMap是如何实现线程安全的。
2.线程、线程池相关知识
线程的3种实现方式。
线程池的原理。
线程池的拒绝策略有哪些。
start和run的区别。
wait和sleep的区别。
3.同步
synchronized和ReetrantLock的区别。
lock和try-lock的区别。
悲观锁和乐观锁的应用场景。
volicate的原理。
4.JVM虚拟机
JVM内存机制。
垃圾回收机制。
调用System.gc(),会马上启动垃圾回收吗?为什么?
垃圾回收算法(详细)。
几种垃圾回收器的优势。
JVM的监控命令(如:jmap,jstat,jstack的使用)。
类加载器有哪些。
类加载机制,双亲委派原则。
5.设计模式
单例模式一般都会让写(懒汉式,饿汉式,双重锁机制,防止反射攻击的)。然后就是熟悉哪些会多问。
6.数据结构和算法
树的三种遍历方式。
括号匹配,数的反转,字符串的反转等等。
二分查找,快速排序,归并排序写的比较多,其他的也要掌握。
7.框架相关知识
IOC是什么,依赖注入是什么。
Spring事物的隔离级别。
Spring的传播性。
动态代理(AOP)的实现方式。
Spring注入bean的方式。
SpringMVC的工作流程。
Hibernate缓存知识。
框架知识我本身了解的也不是很深,这里就不做过多的分享了。
8.数据库知识和sql优化
什么时候会建索引,建索引有什么优劣势。
那些sql语句会使索引失效。
如何优化sql。
B+树原理。
聚合索引的使用。
如果设计过数据库,会问设计数据库应该注意哪些。
9其他相关知识。
redis的数据类型。
先写redis,还是先写数据库,为什么。
String,StringBuffer,StringBuilder的区别.
IO和NIO的区别。
==和equals的区别。
如何重写equals方法。
子类和父类的加载顺序。
java8的新特性。
分布式有没有了解,Dubbo的几种协议。
然后就是一些项目上的问题:遇到的难题;如何处理解决的。
注:以下为"程序员DD"的分享
二、Java多线程
线程池的原理,为什么要创建线程池?创建线程池的方式;
线程的生命周期,什么时候会出现僵死进程;
说说线程安全问题,什么实现线程安全,如何实现线程安全;
创建线程池有哪几个核心参数? 如何合理配置线程池的大小?
volatile、ThreadLocal的使用场景和原理;
ThreadLocal什么时候会出现OOM的情况?为什么?
synchronized、volatile区别、synchronized锁粒度、模拟死锁场景、原子性与可见性;
三、JVM相关
JVM内存模型,GC机制和原理;
GC分哪两种,Minor GC 和Full GC有什么区别?什么时候会触发Full GC?分别采用什么算法?
JVM里的有几种classloader,为什么会有多种?
什么是双亲委派机制?介绍一些运作过程,双亲委派模型的好处;
什么情况下我们需要破坏双亲委派模型;
常见的JVM调优方法有哪些?可以具体到调整哪个参数,调成什么值?
JVM虚拟机内存划分、类加载器、垃圾收集算法、垃圾收集器、class文件结构是如何解析的;
四、Java扩展篇
红黑树的实现原理和应用场景;
NIO是什么?适用于何种场景?
Java9比Java8改进了什么;
HashMap内部的数据结构是什么?底层是怎么实现的?(还可能会延伸考察ConcurrentHashMap与HashMap、HashTable等,考察对技术细节的深入了解程度);
说说反射的用途及实现,反射是不是很慢,我们在项目中是否要避免使用反射;
说说自定义注解的场景及实现;
List 和 Map 区别,Arraylist 与 LinkedList 区别,ArrayList 与 Vector 区别;
五、Spring相关
Spring AOP的实现原理和场景?
Spring bean的作用域和生命周期;
Spring Boot比Spring做了哪些改进? Spring 5比Spring4做了哪些改进;
如何自定义一个Spring Boot Starter?
Spring IOC是什么?优点是什么?
SpringMVC、动态代理、反射、AOP原理、事务隔离级别;
六、中间件篇
Dubbo完整的一次调用链路介绍;
Dubbo支持几种负载均衡策略?
Dubbo Provider服务提供者要控制执行并发请求上限,具体怎么做?
Dubbo启动的时候支持几种配置方式?
了解几种消息中间件产品?各产品的优缺点介绍;
消息中间件如何保证消息的一致性和如何进行消息的重试机制?
Spring Cloud熔断机制介绍;
Spring Cloud对比下Dubbo,什么场景下该使用Spring Cloud?
七、数据库篇
锁机制介绍:行锁、表锁、排他锁、共享锁;
乐观锁的业务场景及实现方式;
事务介绍,分布式事物的理解,常见的解决方案有哪些,什么事两阶段提交、三阶段提交;
MySQL记录binlog的方式主要包括三种模式?每种模式的优缺点是什么?
MySQL锁,悲观锁、乐观锁、排它锁、共享锁、表级锁、行级锁;
分布式事务的原理2阶段提交,同步异步阻塞非阻塞;
数据库事务隔离级别,MySQL默认的隔离级别、Spring如何实现事务、JDBC如何实现事务、嵌套事务实现、分布式事务实现;
SQL的整个解析、执行过程原理、SQL行转列;
八、Redis
Redis为什么这么快?redis采用多线程会有哪些问题?
Redis支持哪几种数据结构;
Redis跳跃表的问题;
Redis单进程单线程的Redis如何能够高并发?
Redis如何使用Redis实现分布式锁?
Redis分布式锁操作的原子性,Redis内部是如何实现的?
面试的过程是发现自己不足的过程,再接再厉,充实自己。最后祝大家都能找到一份满足的工作。