跳槽时时刻刻都在发生,可是我建议你们跳槽以前,先想清楚为何要跳槽。切不可跟风,看到同事一个个都走了,本身也盲目的开始面试起来(期间也没有准备充分),究竟是由于技术缘由(影响本身的发展,偏移本身规划的轨迹),仍是钱给少了,不受重视。mysql
准备不充分的面试,彻底是浪费时间,更是对本身的不负责(若是title很高,当我没说)。面试
今天给你们分享下chenssy在此次跳槽中整理的Java面试大纲,其中大部分都是面试过程当中的面试题,能够对照这查漏补缺,固然了,这里所列的确定不可能覆盖所有方式。redis
大部分状况,这是一场面试的开门题,面试官问这个问题,主要是考察你的概述能力和全局视野。有的人常常抱怨本身天天在堆业务,但没有成长。事实上,不少状况下确实在堆业务,但并非没有成长的。并不是作中间件或者技术架构才是成长,例如咱们的需求分析能力,沟通协做能力,产品思惟能力,抽象建模能力等都是一个很是重要的硬实力。算法
好的,如今进入正文。sql
一、明确项目是作什么的数据库
二、明确项目的价值。(为何作这个项目,它解决了用户什么痛点,它带来什么价值?)设计模式
三、明确项目的功能。(这个项目涉及哪些功能?)数组
四、明确项目的技术。(这个项目用到哪些技术?)缓存
五、明确我的在项目中的位置和做用。(你在这个项目的承担角色?)安全
六、明确项目的总体架构。
七、明确项目的优缺点,若是从新设计你会如何设计。
八、明确项目的亮点。(这个项目有什么亮点?)
九、明确技术成长。(你经过这个项目有哪些技术成长?)
一、List 和 Set 的区别
二、HashSet 是如何保证不重复的
三、HashMap 是线程安全的吗,为何不是线程安全的(最好画图说明多线程环境下不安全)?
四、HashMap 的扩容过程
五、HashMap 1.7 与 1.8 的 区别,说明 1.8 作了哪些优化,如何优化的?
六、final finally finalize
七、强引用 、软引用、 弱引用、虚引用
八、Java反射
九、Arrays.sort 实现原理和 Collection 实现原理
十、LinkedHashMap的应用
十一、cloneable接口实现原理
十二、异常分类以及处理机制
1三、wait和sleep的区别
1四、数组在内存中如何分配
一、synchronized 的实现原理以及锁优化?
二、volatile 的实现原理?
三、Java 的信号灯?
四、synchronized 在静态方法和普通方法的区别?
五、怎么实现全部线程在等待某个事件的发生才会去执行?
六、CAS?CAS 有什么缺陷,如何解决?
七、synchronized 和 lock 有什么区别?
八、Hashtable 是怎么加锁的 ?
九、HashMap 的并发问题?
十、ConcurrenHashMap 介绍?1.8 中为何要用红黑树?
十一、AQS
十二、如何检测死锁?怎么预防死锁?
1三、Java 内存模型?
1四、如何保证多线程下 i++ 结果正确?
1五、线程池的种类,区别和使用场景?
1六、分析线程池的实现原理和线程的调度过程?
1七、线程池如何调优,最大数目如何确认?
1八、ThreadLocal原理,用的时候须要注意什么?
1九、CountDownLatch 和 CyclicBarrier 的用法,以及相互之间的差异?
20、LockSupport工具
2一、Condition接口及其实现原理
2二、Fork/Join框架的理解
2三、分段锁的原理,锁力度减少的思考
2四、八种阻塞队列以及各个阻塞队列的特性
一、BeanFactory 和 FactoryBean?
二、Spring IOC 的理解,其初始化过程?
三、BeanFactory 和 ApplicationContext?
四、Spring Bean 的生命周期,如何被管理的?
五、Spring Bean 的加载过程是怎样的?
六、若是要你实现Spring AOP,请问怎么实现?
七、若是要你实现Spring IOC,你会注意哪些问题?
八、Spring 是如何管理事务的,事务管理机制?
九、Spring 的不一样事务传播行为有哪些,干什么用的?
十、Spring 中用到了那些设计模式?
十一、Spring MVC 的工做原理?
十二、Spring 循环注入的原理?
1三、Spring AOP的理解,各个术语,他们是怎么相互工做的?
1四、Spring 如何保证 Controller 并发的安全?
一、BIO、NIO和AIO
二、Netty 的各大组件
三、Netty的线程模型
四、TCP 粘包/拆包的缘由及解决方法
五、了解哪几种序列化协议?包括使用场景和如何去选择
六、Netty的零拷贝实现
七、Netty的高性能表如今哪些方面
一、Dubbo的底层实现原理和机制
二、描述一个服务从发布到被消费的详细过程
三、分布式系统怎么作服务治理
四、接口的幂等性的概念
五、消息中间件如何解决消息丢失问题
六、Dubbo的服务请求失败怎么处理
七、重连机制会不会形成错误
八、对分布式事务的理解
九、如何实现负载均衡,有哪些算法能够实现?
十、Zookeeper的用途,选举的原理是什么?
十一、数据的垂直拆分水平拆分。
十二、zookeeper原理和适用场景
1三、zookeeper watch机制
1四、redis/zk节点宕机如何处理
1五、分布式集群下如何作到惟一序列号
1六、如何作一个分布式锁
1七、用过哪些MQ,怎么用的,和其余mq比较有什么优缺点,MQ的链接是线程安全的吗
1八、MQ系统的数据如何保证不丢失
1九、列举出你能想到的数据库分库分表策略;分库分表后,如何解决全表查询的问题
20、zookeeper的选举策略
2一、全局ID
一、mysql分页有什么优化
二、悲观锁、乐观锁
三、组合索引,最左原则
四、mysql 的表锁、行锁
五、mysql 性能优化
六、mysql的索引分类:B+,hash;什么状况用什么索引
七、事务的特性和隔离级别
一、Redis用过哪些数据数据,以及Redis底层怎么实现
二、Redis缓存穿透,缓存雪崩
三、如何使用Redis来实现分布式锁
四、Redis的并发竞争问题如何解决
五、Redis持久化的几种方式,优缺点是什么,怎么实现的
六、Redis的缓存失效策略
七、Redis集群,高可用,原理
八、Redis缓存分片
九、Redis的数据淘汰策略
一、详细jvm内存模型
二、讲讲什么状况下回出现内存溢出,内存泄漏?
三、说说Java线程栈
四、JVM 年轻代到年老代的晋升过程的判断条件是什么呢?
五、JVM 出现 fullGC 很频繁,怎么去线上排查问题?
六、类加载为何要使用双亲委派模式,有没有什么场景是打破了这个模式?
七、类的实例化顺序
八、JVM垃圾回收机制,什么时候触发MinorGC等操做
九、JVM 中一次完整的 GC 流程(从 ygc 到 fgc)是怎样的
十、各类回收器,各自优缺点,重点CMS、G1
十一、各类回收算法
十二、OOM错误,stackoverflow错误,permgen space错误
以上问题的答案,若是有什么疑惑,能够加入知识星球进行提问,目前已有230+小伙伴加入。