本人3年开发经验、18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴、今日头条、滴滴等公司offer,岗位是Java后端开发,最终选择去了阿里巴巴。
面试了很多家公司,感觉大部分公司考察的点都差不多,所以将自己的心得记下来,希望能给正在找或者准备找工作的朋友提供一点帮助。另外,目前在阿里也做面试官的工作,身份从求职者变为面试官,看问题的很多角度也不一样,所以下文中既有求职者的视角,也有面试官的视角。
先说下面试流程,一般大公司都有3-4轮技术面,1轮的HR面。就阿里而言,我共经历了4轮技术面,前两轮主要是问基础和项目实现,第3轮是交叉面,两个面试官,主要是问项目实现和拓展。第4轮是部门老大面,主要就问一些架构、技术和业务的理解、个人发展比较抽象的东西了。 HR面主要就是跟你聊聊天,看看你的个人稳定性、价值观、主动性之类的, 一般HR是不会挂人的,但很多人在HR面后挂了,原因其实不是你在HR面的表现不好(少数情况除外),而是你之前几面的表现一般,比60分要高一点(所以没在前面的面试直接挂了你),但是又 没达到80分,这个时候公司基于hc、人才配比、与其他候选人的对比等多个维度考虑,最终决定是否给你offer。 另外要特别说下的是,头条对算法的考察会比较多,我面了4轮技术,每一轮都会问1到2个算法题,大概是leetcode上easy和medium难度。所以想去头条的同学最好先去leetcode上刷刷题。
接下来说技术相关的考察。
总的来说,技术相关的考察主要分为两大块,一是基础,二是经验。
本文主要说基础,下篇文章将说经验。 基础 以下都是我认为面试中经常会被考察到的知识点的整理,不够完整,但大部分都是常见面试题。
集合分为两大块:java.util包下的非线程安全集合和java.util.concurrent下的线程安全集合。 List ArrayList与LinkedList的实现和区别 Map HashMap:了解其数据结构、hash冲突如何解决(链表和红黑树)、扩容时机、扩容时避免rehash的优化 LinkedHashMap:了解基本原理、哪两种有序、如何用它实现LRU TreeMap:了解数据结构、了解其key对象为什么必须要实现Compare接口、如何用它实现一致性哈希 Set Set基本上都是由对应的map实现,简单看看就好
Collections.synchronized 了解其实现原理 CopyOnWriteArrayList 了解写时复制机制、了解其适用场景、思考为什么没有ConcurrentArrayList ConcurrentHashMap 了解实现原理、扩容时做的优化、与HashTable对比。 BlockingQueue 了解LinkedBlockingQueue、ArrayBlockingQueue、DelayQueue、SynchronousQueue
synchronized 了解偏向锁、轻量级锁、重量级锁的概念以及升级机制、以及和ReentrantLock的区别 CAS 了解AtomicInteger实现原理、CAS适用场景、如何实现乐观锁 AQS 了解AQS内部实现、及依靠AQS的同步类比如ReentrantLock、Semaphore、CountDownLatch、CyclicBarrier等的实现 ThreadLocal 了解ThreadLocal使用场景和内部实现 ThreadPoolExecutor 了解线程池的工作原理以及几个重要参数的设置 常见问题
了解Java中的软引用、弱引用、虚引用的适用场景以及释放机制、
了解双亲委派机制
了解BIO和NIO的区别、了解多路复用机制 常见问题
GC:垃圾回收基本原理、几种常见的垃圾回收器的特性、重点了解CMS(或G1)以及一些重要的参数 内存区域:能说清jvm的内存划分
Spring:bean的生命周期、循环依赖问题、spring cloud(如项目中有用过)、AOP的实现、spring事务传播
Dubbo(或其他Rpc框架) 了解一个常用RPC框架如Dubbo的实现:服务发现、路由、异步调用、限流降级、失败重试
RocketMq(或其他消息中间件) 了解一个常用消息中间件如RocketMq的实现:如何保证高可用和高吞吐、消息顺序、重复消费、事务消息、延迟消息、死信队列
redis工作模型、redis持久化、redis过期淘汰机制、redis分布式集群的常见形式、分布式锁、缓存击穿、缓存雪崩、缓存一致性问题
事务隔离级别、锁、索引的数据结构、聚簇索引和非聚簇索引、最左匹配原则、查询优化(explain等命令)
zk大致原理(可以了解下原理相近的Raft算法)、zk实现分布式锁、zk做集群master选举
Storm与Map Reduce、Spark、Flink的比较。Storm高可用、消息ack机制
算法的话不是所有公司都会问,但最好还是准备下,主要是靠刷题,在leetcode上刷个100-200道easy和medium的题,然后对应公司的面经多看看,问题应该不大。
还有其他的就不在这里一一列举了。当然可能还有些没有写上去,还请谅解。如需完整资源可加我QQ:941002778,即可免费领取。
本次给大家分享的内容涵盖知识点有:Java基础、Java集合、JVM、多线程、spring原理、微服务、分布式、Netty、RPC、设计模式、网络、Java算法、数据结构、云计算等等
有什么问题,也非常欢迎大家留言沟通,在这里提前祝大家2020年都能找到一个合适的工作~
特别声明:本文素材来源于网络,仅作为分享学习之用,如有侵权,请联系删除!
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。