粉丝自述:

前言

19 年毕业到现在也两年多了,最近面试了阿里集团(菜鸟网络,蚂蚁金服),网易,滴滴,点我达,最终收到点我达,网易 offer,蚂蚁金服二面挂掉,菜鸟网络一个月了还在流程中...

最终有幸去了网易。

但是要特别感谢点我达的领导及 HR,真的非常非常好,很感谢他们一直的关照和指导。

面试整体事项

  1. 简历要准备好,联系方式一定要正确清晰醒目,项目经历按照时间倒序阐述,注意描述自己在项目中承担的职责,简历的模板尽量选择简洁的,毕竟程序员大部分还是喜欢简单明了的。
  2. 推荐 boss 直聘,我觉得很好用(不是广告)。
  3. 一般的整体面试流程都是电面->现场面->HR 面->等着。
  4. 不要觉得 HR 说让你回去等消息就是 GG 了,他们也要跟你之前的面试官讨论,再向领导汇报,如果说不急可能还要和其他候选人比较,所以 HR 让你回去等消息绝对不是说明你完蛋了。
  5. 面试前准备好自我介绍,1 分钟左右就可以,可以写在纸上,电面可以照着念,等你到了现场面了基本也都快背下来你的自我介绍了。
  6. 准备好扎实的基础,这是一切的根源,没实力怎么都没用的。
  7. 面试中你可以把你的面试官往你会的知识上引导(我遇到过你会什么他不问什么的)。
  8. 遇到了设计类题目不要着急,面试官不是为了让你几分钟设计一个高并发高可用设计模式完美的架构,只是想看看你的思路,看看你应变的能力,然后给你些提示看看你能否迅速的调整。
  9. offer 都会有的,不要着急,把面试当成一个交流的过程。

需要准备的知识

以下为在近期面试中比较有印象的问题,也就不分公司了,因为没什么意义,大致分类记录一下,目前只想起这么多,不过一定要知道这些问题只是冰山一角,就算都会了也不能怎么样,最最重要的,还是坚实的基础,清醒的头脑。

由于篇幅原因,以后都只放出了面试题目,大家也可以自测一下,看能答出多少题目来。

java基础

  1. HashMap 的源码,实现原理,JDK8 中对 HashMap 做了怎样的优化。
  2. HaspMap 扩容是怎样扩容的,为什么都是 2 的 N 次幂的大小。
  3. HashMap,HashTable,ConcurrentHashMap 的区别。
  4. 极高并发下 HashTable 和 ConcurrentHashMap 哪个性能更好,为什么,如何实现的。
  5. HashMap 在高并发下如果没有处理线程安全会有怎样的安全隐患,具体表现是什么。
  6. java 中四种修饰符的限制范围。
  7. Object 类中的方法。
  8. 接口和抽象类的区别,注意 JDK8 的接口可以有实现。
  9. 动态代理的两种方式,以及区别。
  10. Java 序列化的方式。
  11. 传值和传引用的区别,Java 是怎么样的,有没有传值引用。
  12. 一个 ArrayList 在循环过程中删除,会不会出问题,为什么。
  13. @transactional 注解在什么情况下会失效,为什么。

数据结构和算法

  1. B+树
  2. 快速排序,堆排序,插入排序(其实八大排序算法都应该了解
  3. 一致性 Hash 算法,一致性 Hash 算法的应用

JVM

  1. JVM 的内存结构。
  2. JVM 方法栈的工作过程,方法栈和本地方法栈有什么区别。
  3. JVM 的栈中引用如何和堆中的对象产生关联。
  4. 可以了解一下逃逸分析技术。
  5. GC 的常见算法,CMS 以及 G1 的垃圾回收过程,CMS 的各个阶段哪两个是 Stop the world 的,CMS 会不会产生碎片,G1 的优势。
  6. 标记清除和标记整理算法的理解以及优缺点。
  7. eden survivor 区的比例,为什么是这个比例,eden survivor 的工作过程。
  8. JVM 如何判断一个对象是否该被 GC,可以视为 root 的都有哪几种类型。
  9. 强软弱虚引用的区别以及 GC 对他们执行怎样的操作。
  10. Java 是否可以 GC 直接内存。
  11. Java 类加载的过程。
  12. 双亲委派模型的过程以及优势。
  13. 常用的 JVM 调优参数。
  14. dump 文件的分析。
  15. Java 有没有主动触发 GC 的方式(没有)。

多线程

  1. Java 实现多线程有哪几种方式。
  2. Callable 和 Future 的了解。
  3. 线程池的参数有哪些,在线程池创建一个线程的过程。
  4. volitile 关键字的作用,原理。
  5. synchronized 关键字的用法,优缺点。
  6. Lock 接口有哪些实现类,使用场景是什么。
  7. 可重入锁的用处及实现原理,写时复制的过程,读写锁,分段锁(ConcurrentHashMap 中的 segment)。
  8. 悲观锁,乐观锁,优缺点,CAS 有什么缺陷,该如何解决。
  9. ABC 三个线程如何保证顺序执行。
  10. 线程的状态都有哪些。
  11. sleep 和 wait 的区别。
  12. notify 和 notifyall 的区别。
  13. ThreadLocal 的了解,实现原理。

数据库相关

  1. 常见的数据库优化手段
  2. 索引的优缺点,什么字段上建立索引
  3. 数据库连接池。
  4. durid 的常用配置。

计算机网络

  1. TCP,UDP 区别。
  2. 三次握手,四次挥手,为什么要四次挥手。
  3. 长连接和短连接。
  4. 连接池适合长连接还是短连接。

设计模式

  1. 观察者模式
  2. 代理模式
  3. 单例模式,有五种写法
  4. 可以考 Spring 中使用了哪些设计模式

分布式相关

  1. 分布式事务的控制。
  2. 分布式锁如何设计。
  3. 分布式 session 如何设计。
  4. dubbo 的组件有哪些,各有什么作用。
  5. zookeeper 的负载均衡算法有哪些。
  6. dubbo 是如何利用接口就可以通信的。

缓存相关

  1. redis 和 memcached 的区别。
  2. redis 支持哪些数据结构。
  3. redis 是单线程的么,所有的工作都是单线程么。
  4. redis 如何存储一个 String 的。
  5. redis 的部署方式,主从,集群。
  6. redis 的哨兵模式,一个 key 值如何在 redis 集群中找到存储在哪里。
  7. redis 持久化策略。

框架相关

  1. SpringMVC 的 Controller 是如何将参数和前端传来的数据一一对应的。
  2. Mybatis 如何找到指定的 Mapper 的,如何完成查询的。
  3. Quartz 是如何完成定时任务的。
  4. 自定义注解的实现。
  5. Spring 使用了哪些设计模式。
  6. Spring 的 IOC 有什么优势。
  7. Spring 如何维护它拥有的 bean。

一些较新的东西

  1. JDK8 的新特性,流的概念及优势,为什么有这种优势。
  2. 区块链了解
  3. 如何设计双 11 交易总额面板,要做到高并发高可用。

一些小建议

  1. 可以去 leetcode 上刷题换换思路。
  2. 八大排序算法一定要手敲一遍(快排,堆排尤其重要)。
  3. 了解一些新兴的技术。
  4. 面试之后面试官都会问你有没有什么问题,千万不要没问题,也别傻乎乎的问一些敏感问题。
  5. 了解你要面试的公司的产品及竞争产品。

总结

无论是哪家公司,都很重视高并发高可用的技术,重视基础,重视 JVM。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。其实我写了这么多,只是我自己的总结,并不一定适用于所有人,相信经过一些面试,大家都会有这些感触。

如果这些文字能够帮到你,那就最好了,帮不到就当是我自己的一个记录。

最后,希望大家都能找到适合自己的公司,开开心心的撸代码~