本人两年开发经验、18年年末开始跑路找工做,在互联网寒冬下成功拿到阿里巴巴、今日头条、滴滴等公司offer,岗位是Java后端开发,最终选择去了阿里巴巴。html
面试了不少家公司,感受大部分公司考察的点都差很少,因此将本身的心得记下来,但愿能给正在找或者准备找工做的朋友提供一点帮助。另外,目前在阿里也作面试官的工做,身份从求职者变为面试官,看问题的不少角度也不同,因此下文中既有求职者的视角,也有面试官的视角。java
更多文章见我的博客:github.com/farmerjohng…mysql
公众号(刚申请,以后文章会往上面发):git
先说下面试流程,通常大公司都有3-4轮技术面,1轮的HR面。就阿里而言,我共经历了4轮技术面,前两轮主要是问基础和项目实现,第3轮是交叉面,两个面试官,主要是问项目实现和拓展。第4轮是部门老大面,主要就问一些架构、技术和业务的理解、我的发展比较抽象的东西了。github
HR面主要就是跟你聊聊天,看看你的我的稳定性、价值观、主动性之类的,通常HR是不会挂人的,但不少人在HR面后挂了,缘由其实不是你在HR面的表现很差(少数状况除外),而是你以前几面的表现通常,比60分要高一点(因此没在前面的面试直接挂了你),可是又没达到80分,这个时候公司基于hc、人才配比、与其余候选人的对比等多个维度考虑,最终决定是否给你offer。面试
另外要特别说下的是,今日头条对算法的考察会比较多,我面了4轮技术,每一轮都会问1到2个算法题,大概是leetcode上easy和medium难度。因此想去头条的同窗最好先去leetcode上刷刷题。redis
另外,在求职的过程当中也碰到过少数没有素质的面试官,好比一上来就一副很不屑的语气,话没说两句开始diss你的项目,给人的体验很很差。因此也请各位面试官或未来要作面试官的同窗,能在面试的过程当中保持基本的礼貌和尊重,就像在阿里常说的:你面试别人的时候,别人也在面试着你。算法
最重要的一点,不要由于几回的面试失败就开始怀疑本身,永远记住,面试的结果=实力+运气。有时候你擅长的东西可能面试官根本不会,因此他也不可能花不少时间去问他不懂的东西;有时候可能他问你的你都会,可是可能由于对方提问方式、语气等缘由,答的就是不畅。spring
接下来讲技术相关的考察。sql
总的来讲,技术相关的考察主要分为两大块,一是基础,二是经验。
基础包括java基础、数据库、中间件等,来自于平常的积累和面试前的准备。
经验包括以往作过的项目、解决的问题、以及一些场景题(好比你的项目若是流量大了十倍如何保证可用)。
本文主要说基础,下篇文章将说经验。
如下都是我认为面试中常常会被考察到的知识点的整理,不够完整,但大部分都是常见面试题。
集合分为两大块:java.util包下的非线程安全集合和java.util.concurrent下的线程安全集合。
ArrayList与LinkedList的实现和区别
HashMap:了解其数据结构、hash冲突如何解决(链表和红黑树)、扩容时机、扩容时避免rehash的优化
LinkedHashMap:了解基本原理、哪两种有序、如何用它实现LRU
TreeMap:了解数据结构、了解其key对象为何必需要实现Compare接口、如何用它实现一致性哈希
Set基本上都是由对应的map实现,简单看看就好
了解其实现原理
了解写时复制机制、了解其适用场景、思考为何没有ConcurrentArrayList
了解实现原理、扩容时作的优化、与HashTable对比。
了解LinkedBlockingQueue、ArrayBlockingQueue、DelayQueue、SynchronousQueue
了解偏向锁、轻量级锁、重量级锁的概念以及升级机制、以及和ReentrantLock的区别
了解AtomicInteger实现原理、CAS适用场景、如何实现乐观锁
了解AQS内部实现、及依靠AQS的同步类好比ReentrantLock、Semaphore、CountDownLatch、CyclicBarrier等的实现
了解ThreadLocal使用场景和内部实现
了解线程池的工做原理以及几个重要参数的设置
推荐文章:
死磕Synchronized底层实现--概论(比较深刻)
了解Java中的软引用、弱引用、虚引用的适用场景以及释放机制
推荐文章:
Java引用类型原理剖析(比较深刻)
了解双亲委派机制
了解BIO和NIO的区别、了解多路复用机制
同步阻塞、同步非阻塞、异步的区别?
select、poll、eopll的区别?
java NIO与BIO的区别?
refactor线程模型是什么?
垃圾回收基本原理、几种常见的垃圾回收器的特性、重点了解CMS(或G1)以及一些重要的参数
能说清jvm的内存划分
推荐文章:JVM垃圾回收历险
bean的生命周期、循环依赖问题、spring cloud(如项目中有用过)、AOP的实现、spring事务传播
java动态代理和cglib动态代理的区别(常常结合spring一块儿问因此就放这里了)
spring中bean的生命周期是怎样的?
属性注入和构造器注入哪一种会有循环依赖的问题?
了解一个经常使用RPC框架如Dubbo的实现:服务发现、路由、异步调用、限流降级、失败重试
了解一个经常使用消息中间件如RocketMq的实现:如何保证高可用和高吞吐、消息顺序、重复消费、事务消息、延迟消息、死信队列
redis工做模型、redis持久化、redis过时淘汰机制、redis分布式集群的常见形式、分布式锁、缓存击穿、缓存雪崩、缓存一致性问题
推荐书籍:《Redis 设计与实现》
推荐文章:
事务隔离级别、锁、索引的数据结构、聚簇索引和非聚簇索引、最左匹配原则、查询优化(explain等命令)
zk大体原理(能够了解下原理相近的Raft算法)、zk实现分布式锁、zk作集群master选举
HBase适用的场景、架构、merge和split、查写数据的流程。
推荐文章:hbasefly.com/2017/07/26/… 及该博客下相关文章
Storm与Map Reduce、Spark、Flink的比较。Storm高可用、消息ack机制
算法的话不是全部公司都会问,但最好仍是准备下,主要是靠刷题,在leetcode上刷个100-200道easy和medium的题,而后对应公司的面经多看看,问题应该不大。
我所在的部门是阿里巴巴菜鸟网络下的国际事业部,主要是为速卖通、天猫海外、lazada等跨境电商提供国际物流解决方案。国际化是阿里巴巴集团将来三年五年的战略目标之一,目前业务也是高速发展的阶段,集团这几年也是往菜鸟这边在大量投入人才和资源。另外,菜鸟p6就有期权(集团是p7)。
邮箱: farmercoding@163.com
招聘岗位:Java开发,base杭州
要求: