作为一个毕业两年的程序员, 最近一直在寻找合适的机会能够换一个环境。
一是寻找一个更加宽阔的舞台不断的提升自己;二是让自己走出现在的舒适区域,迎接更多的挑战和认识更多的人;当然还有为了获得更好的一份收入。
下面记录了我的面试经验,一方面用作后期自己回顾知识点,另一方便给正要面试的人一些经验。
一面
- 项目介绍
- 项目中如何保证数据一致性的
- 存在的问题
- jvm 内存
- 程序计数器的作用
- gc 算法, 垃圾收集器
- spring事务,事务实现的机制,如何保证事务的
- 悲观锁,乐观锁
- HashMap
- 红黑树,B+树
- 数据库死锁,如何防止死锁
二面
二面开始于5道题目,整体感觉还是比较难的。面试的前一天给我发的题目,然后晚上下班后(9点左右)我做了5个小时才完成。 第二天面试的时候,主要围绕题目进行展开和发散。
从第一个题目延伸出(转账):
- 分布式事务的保证。具体的解决方案;
- 接口的幂等性;
- 如果向某个账户转账在高并发环境下,设计的接口有什么问题(数据库瓶颈)
- 如何解决上述的问题
- 如果账户表很大,具有亿万级别,如何提高查询效率(分库分表)
- 分库分表具体操作,什么时候分库,什么时候分表,各个使用场景
- mysql主从
- mysql如何保证主从的数据一致性
- 数据库的容灾
第二个题目: 抢红包
- 抢红包的实现方案;(我给出的解决方案是存下抢红包的操作,然后乐观锁更新金额,保证数据的最终一致性)
- 有没有优化空间
- 春晚红包方案(包括限流,网络瞬间抖动,数据一致性)这一点聊了很久
- 对分布式的看法
- 开源中间件熟悉哪些?(只是做简单了解)
三面
- 读书时候的经历? 介绍读书时候的项目
- 项目一(支付营销系统)的具体介绍, 架构,项目中某个操作的具体流程图,如何压测? 性能优化? 项目中机器的台数,机器扩容标准? 线程池大小?线程数设置标准?
- 平时用到了哪些集合?hashmap的问题?cpu 100%出现的情况?Treeset的实现?
- 分布式事务,秒杀系统的要求?秒杀系统的设计原则?注意事项?项目中遇到的问题?解决放肆?
- 项目二(分布式调度系统)的具体情况,架构?中间某些步骤的具体的设计思路。(这个挖的很深,而且面试官确实很厉害,几分钟能够了解你整个项目的大致情况,zz.java.tedu.cn知道你设计的痛点,然后咨询你如何解决的)
- kafka消息可靠性保证?其他中间件有没有了解过?平时阅读什么技术?
HR面试
HR面试主要问过往的经历,以及个人的职业规划,就职意向等。
个人总结
在程序员的这条路上我一直在学习,自认为在同辈中水平较好,但通过这次面试我发现自己还有很多不足。幸运的是,在前进的道路上得到了专业老师的指点,让我能够在面试的时候做好准备。
面试结束,老师分析我的思路不够开阔,看待问题不够深入,比如HashMap出现100%CPU的情况以及原因。最后我还是拿到了offer。
如果你也觉得自学是一件很难的事情,需要耗费你大量的精力,你急需找到一个更轻易高效的学习方法,那么参加培训是你最好的选择。