大厂面试对技术的考核基本分为三个层次:对于基础知识的考核、对于项目经验的考核、对于项目深度的考核。
a.基础知识主要考核你对 Java 语言本身原理的理解以及各种框架的原理理解。知识点包括但不限于:
集合 HashMap 的原理,与 Hashtable、ConcurrentHashMap 的区别?
Java 线程池的核心属性以及处理流程
Java 并发包原理、Synchronized关键字、锁
线程的生命周期
JVM类加载机制
JVM内存模型
JVM分代以及垃圾回收机制
Spring Bean 容器生命周期
Spring AOP 原理
Dubbo 请求流程以及原理
数据库 SQL 优化、数据库索引、索引原理
……
面试官一般都会针对简历中描写的知识点刨根问底,不懂的技术千万不要写了解。前段时间参加技术沙龙,京东架构师张开涛、腾讯高级工程师刘泽峰都表示大厂招人现在更注重技术能力的细分板块,你必须在某领域有自己独到的理解。
b.项目理解一般会让你画个架构图,然后从架构图出发,你得清楚每个模块的作用,每个框架的原理以及与其他框架的区别。是否有能拿得出手的项目,并对其原理了如指掌,很大程度关系到你能否通过这次面试。
c.项目思考深度在这一个层次上考核的是你对开源框架的思考深度,这些框架到底好不好,好在哪里,不好在哪里,有什么可以改进的地方。你不仅要对项目本身理解足够深刻,还要跳出项目本身,去思考开源框架本身的问题。
那么要想成功进入BATJ等一线大厂,应该掌握哪些技术能力呢?
1、要具备扎实的Java基础
这里所谓扎实的Java基础不是我们通常所理解的Java语法、面向对象的概念,而是能深刻理解Java的多线程开发,熟练使用NIO技术优化网络编程,了解JVM的底层机制,具备底层性能调优的能力,这些技能恰恰是Java开发人员往往忽略的基础。
2、深入学习常用开源框架
为什么BATJ的面试官总是喜欢问源码?其实我们常用的Spring、MyBaits这样的框架可以说是JAVA里面最经典的教科书,从中你能学习到很多写代码的经验技巧,而去悟开源框架中蕴含的优雅架构设计之道这才是最重要的。
3、高性能分布式系统设计与应用
根据双十一日志统计,前端系统有效请求约60w以上的QPS ,而后端cache的集群峰值近2000w/s、单机也近30w/s,互联网大厂的架构师面对的就是这样的生产环境,所以分布式、缓存、消息这样搭建高性能系统的技术必须掌握。
4、微服务(分布式服务技术)
微服务架构是一种架构风格,整个应用被划分并设计为以业务域为模型的松散耦合的独立服务,方便横向扩展能力、伸缩性强、便于开发和维护等等这些是微服务与生俱来的优势。
5、沟通合作的能力
程序员的战斗,往往不是一个人的战斗,我们如何在一个平台下高效的去重,进行代码review,对功能进行调整、debug,做到在统一的规划下步步为营,混乱的堆代码的过程中找到自己的记录。这一切都依赖于有效的工具,Git、Maven和jenkins。
作为一名程序员,谁没跳过槽,“6”招让你“空降”大厂