最近是不是面试的越来越多啊,或者说备战金九银十呢?
最近也有很多小伙伴在后台和我联系,说面试的时候遇到的一些问题,其实面试多了你会发现一个规律,如果一个公司你一面过的很顺利,后面不管三面四面还是五面,都会比较顺利。因为大家的提问方式,角度都很类似,很多时候都是在跟不同的面试官说同样的话。
多数的公司总体上面试都是以自我介绍+项目介绍+项目细节/难点提问+基础知识点考核+算法题这个流程下来的。有些公司可能还会问几个实际的场景类的问题,这个环节阿里是必问的,这种问题通常是没有正确答案的,就看个人的理解,个人的积累了。剩下的就没啥了,都是换汤不换药,聊项目就看你自己对你自己的项目是否理解的透彻,比如经常问你你为什么选择这个技术,为什么这么处理之类的,常考的基础的知识点就那么多,最后算法就是靠刷题。
问题
*ZooKeeper*
1. CAP定理
2. ZAB协议
3. Leader选举算法和流程
*Redis *
1. Redis的应用场景
2. Redis支持的数据类型(必考)
3. zset跳表的数据结构(必考)
4. Redis的数据过期策略(必考)
5. Redis的LRU过期策略的具体实现
6. 如何解决Redis缓存雪崩,缓存穿透问题
7. Redis的持久化机制(必考)
8. Redis的管道pipeline
*Mysql *
1. 事务的基本要素
2. 事务隔离级别(必考)
3. 如何解决事务的并发问题(脏读,幻读)(必考)
4. MVCC多版本并发控制(必考)
5. binlog,redolog,undolog都是什么,起什么作用
6. InnoDB的行锁/表锁
7. myisam和innodb的区别,什么时候选择myisam
8. 为什么选择B+树作为索引结构(必考)
9. 索引B+树的叶子节点都可以存哪些东西(必考)
10. 查询在什么时候不走(预期中的)索引(必考)
11. sql如何优化
12. explain是如何解析sql的
13. order by原理
*JVM *
1. 运行时数据区域(内存模型)(必考)
2. 垃圾回收机制(必考)
3. 垃圾回收算法(必考)
4. Minor GC和Full GC触发条件
5. GC中Stop the world(STW)
6. 各垃圾回收器的特点及区别
7. 双亲委派模型
8. JDBC和双亲委派模型关系
9. JVM锁优化和锁膨胀过程
*Java基础 *
1. HashMap和ConcurrentHashMap区别(必考)
2. ConcurrentHashMap的数据结构(必考)
3. 高并发HashMap的环是如何产生的
4. volatile作用(必考)
5. Atomic类如何保证原子性(CAS操作)(必考)
6. synchronized和Lock的区别(必考)
7. ThreadLocal的原理和实现
8. 为什么要使用线程池(必考)
9. 核心线程池ThreadPoolExecutor的参数(必考)
10. ThreadPoolExecutor的工作流程(必考)
11. 如何控制线程池线程的优先级
12. 线程之间如何通信
13. Boolean占几个字节
14. jdk1.8/jdk1.7都分别新增了哪些特性
15. Exception和Error
16. Object类内的方法
*Spring *
1. Spring的IOC/AOP的实现(必考)
2. 动态代理的实现方式(必考)
3. Spring如何解决循环依赖(三级缓存)(必考)
4. Spring的后置处理器
5. Spring的@Transactional如何实现的(必考)
6. Spring的事务传播级别
7. BeanFactory和ApplicationContext的联系和区别
*其他 *
1. 高并发系统的限流如何实现
2. 高并发秒杀系统的设计
3. 负载均衡如何设计
而除了这些之外,还有一些其他的问题,已经为大家分门别类地准备好了,我们来看一下吧
大厂面试题
身边的朋友帮忙整理的,可以给大家提供一下参考,针对的是像冲刺一下进大厂的老铁
各技术点面试题
将自己收集总结的面试题,按照技术分门别类的进行了分类,可以有针对性的,针对自己的技术薄弱点进行复习,主要针对的是短时间内需要找工作的朋友
当然只有面试怎么可以,针对面试题,还有相应的学习文档进行支撑