懵逼!阿里一面就被虐了,幸获内推华为技术四面,成功拿到offer

上个月,哥们从某小厂离职,转投阿里云,简历优秀,很顺利地拿到了面试通知,但之后的进展却让哥们怀疑人生了,或者说让哥们懵逼的是,面试阿里云居然第一面就被吊打?让哥们开始怀疑自己,是不是这些年工作下来,自己没有一丁点的进步呢?

幸运的是,经过他朋友推荐,去面试了华为,面试华为的过程极为顺利,很快就拿到了offer。这让哥们更弄不懂了,4面拿华为offer的水平,面试阿里居然一面就被吊打?

索性,哥们想分享一下这次的面试经历,让各位老铁好好帮他参考参考,出一出主意!

另外,我下文还整理了一些哥们的复习资料,有需要的朋友转发并关注,私信回复我“面试资料”即可获得免费领取方式!

阿里一面凉经(一面竟然就问了2小时,什么情况?)

这次一面感觉是在打心理战,哥们自己的心里防线基本是被击溃,面到怀疑人生的程度,所以过程感觉不是太好,很多题哥们自己也感觉没答好,要么答得“缺胳膊少腿”,要么就是“画蛇添足”。

先是聊项目,从项目的架构设计到部署流程。

1. Java容器有哪些?哪些是同步容器,哪些是并发容器?

2. ArrayList和LinkedList的插入和访问的时间复杂度?

3. Java反射原理, 注解原理?

4. 新生代分为几个区?使用什么算法进行垃圾回收?为什么使用这个算法?

5. HashMap在什么情况下会扩容,或者有哪些操作会导致扩容?

6. HashMap push方法的执行过程?

7. HashMap检测到hash冲突后,将元素插入在链表的末尾还是开头?

8. 1.8还采用了红黑树,讲讲红黑树的特性,为什么人家一定要用红黑树而不是AVL、B树之类的?

9. https和http区别,有没有用过其他安全传输手段?

10. 线程池的工作原理,几个重要参数,然后给了具体几个参数分析线程池会怎么做,最后问阻塞队列的作用是什么?

11. Linux怎么查看系统负载情况?

12. 请详细描述springmvc处理请求全流程?

13. 讲一讲AtomicInteger,为什么要用CAS而不是synchronized?

14. 查询中哪些情况不会使用索引?

15. 数据库索引,底层是怎样实现的,为什么要用B树索引?

16. Mysql主从同步的实现原理?

17. MySQL是怎么用B+树?

18. 谈谈数据库乐观锁与悲观锁?

19. 有使用过哪些NoSQL数据库?MongoDB和Redis适用哪些场景?

20. 描述分布式事务之TCC服务设计?

21. Redis和memcache有什么区别?Redis为什么比memcache有优势?

22. 考虑redis的时候,有没有考虑容量?大概数据量会有多少?

23. 谈谈分布式锁、以及分布式全局唯一ID的实现比较?

24. 集群监控的时候,重点需要关注哪些技术指标?这些指标如何优化?

25. 从千万的数据到亿级的数据,会面临哪些技术挑战?你的技术解决思路?

26. 最近两年遇到的最大的挫折,从挫折中学到了什么?

27.最近有没有学习过新技术?

华为四面:3轮技术面+HR面(华为真经,值得参考)

华为面试过程很顺,一面问得比较基础,所以哥们整个人都还挺自信的一个状态,面试官也全程是一个比较“和蔼”的问题方式,所以比较轻松,因此面试得顺利,拿offer也快。以下是哥们华为4面的技术题,不包括HR面。

华为技术一面:

1. 简单说一下面向对象的特征以及六大原则

2. 谈谈final、finally、finalize的区别

3. Java中==、equals与hashCode的区别和联系

4. 谈谈Java容器ArrayList、LinkedList、HashMap、HashSet的理解,以及应用场景

5. 谈谈线程的基本状态,其中的wait() sleep() yield()方法的区别。

6. JVM性能调优的监控工具了解那些?

7. 简单谈谈JVM内存模型,以及volatile关键字

8. 垃圾收集器与内存分配策略

9. 垃圾收集算法

10. MySQL几种常用的存储引擎区别

11. 数据库的隔离级别

12. 5亿整数的大文件,怎么排?

华为技术二面:

1. Java内存模型

2. full gc怎么触发?

3. gc算法

4. JVM回收策略

5. ClassLoader原理和应用

6. 高吞吐量的话用哪种gc算法

7. ConcurrentHashMap和HashMap

8. volatile的底层如何实现,怎么就能保住可见性了?

9. 有参与过开源的项目吗?

10. 线程池原理,拒绝策略,核心线程数

11. 1亿个手机号码,判断重复

12. 线程之间的交互方式有哪些?有没有线程交互的封装类 (join)?

华为技术三面:

1. 两次点击,怎么防止重复下订单?

2. 数据库表设计,索引

3. Redis的缓存淘汰策略、更新策略

4. dubbo、netty、RPC介绍原理

5. 限流算法

6. zk挂了怎么办?

7. 分布式锁的实现方式,zk实现和Redis实现的比较

8. 秒杀场景设计,应付突然的爆发流量

9. 分布式数据一致性

10. 一致性哈希

11. 消息队列原理介绍

12. 注解的原理

13. 数据库原理,数据库中间件,索引优化

14. ioc原理、aop原理和应用

15. 大数据相关,MapReduce

16. Docker的原理


2019大厂面试题及答案

实际上,哥们并不是一个幸运的人,而是一个努力的人,今天的这些,也全是靠哥们的努力得来的,尽管阿里云一面就凉,但能进入华为,也算是哥们多年的累积,以下是哥们分享的个人的一个学习方法和经验总结。

学习方法及经验总结

以下所展示的全部资料,均可以免费分享 转发+关注,然后私信回复“面试资料”即可。

(1)多刷题

自己多刷一些面试题是非常重要的,即使是在自己不需要面试的情况下,也要经常了解现在的大厂小厂面试都会问一些什么?现在比较流行的技术是什么等等诸如此类。那么哥们是如何刷题的呢?刷题主要分为Java技术以及算法两大类,搜集了目前比较新的一些题册,包括【Java核心知识】以及【算法刷题】,如算法方面就有LeetCode。

算法刷题LeetCode:

(2)多看看技术牛的实战书

实际上很多人目前的一个状态是缺乏实战经验,或者说是不知道该如何上手实战。那么,看一些技术比较过硬的大牛写的实战书籍对自己是很有好处的,多少能够学习到一些实战经验。目前我手上整理到的实战书籍也算是比较全面,包括Spring全家桶、JVM、并发编程技术、Redis相关、MySQL调优、Tomcat、ZooKeeper等高级技术。

(3)多交流,多思考

最后要强调的重点就是——多交流,多思考。现在很多程序员陷入一个怪圈,整天只会在办公室里机械的工作,实际上程序员要想有很大很明显的进步,交流是少不了的。那么怎么结识比自己厉害的技术牛呢?实际上渠道有很多,哥们个人的做法是:①看一些技术直播,在直播间交友;②加一些技术性的交流群,多交流问题;③参加一些线下活动,如面基、研讨会等等。

写在最后

学习如攀登,虽然有身心的疲惫,但更有沿途的优美风光,更无论登顶之后的极目远眺。之后,你总会感叹曾经的付出是值得的。

以上所展示的面试题也好、学习资料也罢,均可以免费分享给大家,有需要的老铁请转发+关注,然后私信回复“面试资料”即可。

你可能感兴趣的:(懵逼!阿里一面就被虐了,幸获内推华为技术四面,成功拿到offer)