本文主要记录题主备战秋招及秋招经过的帖子
编程语言
1、Java语言基础:面向对象的概念、数据类型、装箱/拆箱、值传递/引用传递、String 类、关键字(final、static、super、this等)、抽象类/接口、异常、IO流、反射、动态代理、序列化等。
2、Java集合类:常见的集合类源码一定要看一看。比如:ArrayList、LinkedList、HashMap、TreeMap、LinkedHashMap(实现LRU)、HashSet等。这部分非常的重要,特别是 HashMap,“出镜率”超级高,一定要搞懂其中每一个知识点。
3、Java并发/多线程:主要是看 java.util.concurrent 包下相关类的源码。Java内存模型、线程的状态及转换、ThreadLocal、synchronized、ReentrantLock、volatile、CAS、AQS、BlockingQueue、CountDownLatch/CyclicBarrier、Exectuor、Java线程池等。
4、Java虚拟机:这部分基础看周志华的《深入理解Java虚拟机》就够了,自己可以再结合相关案例学习了 JVM调优。需要掌握的知识点:运行时数据区、垃圾回收机制、垃圾收集器、类文件结构、类加载机制、双亲委派模型、早期/晚期优化、JVM监控工具等。
5、JavaWeb:JDBC、Servlet、Cookie、Session 等 web 技术还是要了解的。
计算机基础
1、数据结构与算法:这部分的重要性不用过多强调了,直接做一个详细的刷题计划吧。三部分:基础数据结构、剑指Offer、LeetCode。
2、计算机操作系统:进程与线程的区别、线程/进程间的通信方式、死锁的概念/检测、避免内存管理等。操作系统这部分知识点非常多,但是常问的就是那么几块,建议找一本书先看一遍,如果迷惑也不要紧,再结合一些大佬的笔记或者面经总结一些高频题,问题也不是很大。
3、计算机网络:个人感觉在 Java 研发岗位的面试中,计算机网络的问题要比操作系统的多一些。计算机网络主要的知识点:五层网络模型(每一层的作用、主要协议等)、TCP三次握手/四次挥手、UDP和TCP的区别、可靠传输、HTTP 和 HTTPS 的区别、HTTPS 的工作原理等等。
4、Linux:至少能说出几个常用的 Linux 指令吧?也遇到过一些问的比较具体的,但是大部分都是让你随便说几个,所以快速的了解下即可,如果有时间可以多看看。
5、设计模式:这也是面试中一个比较高频的点,至少能说出 5 种设计模式及思想吧?单
例、工厂、代理这些常见的还是要懂的。对于面试而言,也没有必要 23 种都搞的滚瓜烂熟,最好的是结合源码或者项目说几个,这样比较加分,说明你是学以致用。
PS:对于校招,编程语言基础和计算机基础并列第一重要。**“基础”才是王道!**只要你基础好,不愁拿不到 offer!一定要尽可能的深入理解每个知识点。
数据库
1、SQL 语句:CRUD 你真的会吗?今年身边很多同学面试中就栽在了写 SQL 语句上。千万重视下,基础的 SQL 语句要熟!
2、MySQL:MySQL 是目前互联网公司用的比较多的数据库,所以如果你要选择一个数据库进行学习,那么就建议学 MySQL 了。需要了解:索引、事务、锁、存储引擎、主从复制、分库分表等,最好再懂一些数据库调优方面的知识。
3、Redis:Redis 我认为是 Java 研发工程师必问的一个知识模块了,毕竟现在互联网公司服务数据量都很大,为了减轻数据库压力,一般都会使用缓存的,那么 Redis 就是用的最多的。需要了解 Redis 基本的数据类型、持久化方式、缓存和数据库双写一致性问题、缓存穿透、缓存雪崩等。
————————————————
框架
1、Spring:AOP、IOC(Bean 的生命周期、作用域等)、事务等。对于 AOP 和 IOC 看源码确实困难比较大,费时易忘。建议去百度搜下 AOP/IOC 的简洁版实现,可以跟着练习加深印象。
2、SpringBoot:现在很多互联网公司都是直接用 SpringBoot 的,当然如果你一直用Spring,不懂 SpringBoot 也没关系,二者会其一即可,有时间最好都学学。
3、SpringMVC:核心组件、处理请求的流程、入口类等关键类的源码最好也能看下。
4、MyBatis:这个我觉得倒不用看源码了,了解下 MyBatis 的一级和二级缓存机制、分页方式、延迟加载等。个人感觉看面经或者我的秋招笔记就够了。
对于框架而言:校招面试要求不是只懂怎么配置使用,而是会考察源码、底层原理。
分布式/微服务
1、消息队列:这个模块我觉得也是校招 Java 研发岗位必须掌握的了。建议学习 Kafka, 当然结合自己情况,学习哪个都行,只是说最好学习现在流行的。需要学习的知识点:使用场景、如何保证消息不被重复消费(幂等)、如何保证可靠传输、如何保证顺序性等等。
2、注册中心:建议学习 Zookeeper,直接看《从Paxos到Zookeeper分布式一致性原理与实践》。书里面对 Paxos 算法、ZAB协议、两阶段/三阶段提交都做了讲解。
3、分布式框架:建议学习 Dubbo,毕竟阿里开源的,看官网就是最好的学习资料。当然你学习 SpringCloud 也没有问题,还是那句话结合自己的情况选择。如果你准备学习Dubbo,要看的知识点直接去看官网即可。
4、分布式事务:需要知道常用的分布式事务解决方案,最好能结合自己的项目说一说,这块知识点也是比较容易扩展的,一定要多思考,不要只懂一点点就去装 X 说,面试官一扩展,就被吊打了。
5、分布式锁:需要知道常见实现分布式锁的方式。
对于分布式相关的知识点目前校招没有明确的说必须会,但是我认为大厂默认你都要懂一些了,有过相关项目经验的肯定比较加分的。
收的简历太多了,基础问题一般都能回答出来,他想找和“别人”不一样的同学,看 到我简历上写的项目是分布式的,所以就看看我这块知识掌握的怎么样?即便回答的不是很好,但是也看出和别的同学的不一样,所以轻松过了面试。
建议在准备面试的时候,基础肯定是最重要的,但是最好学一些分布式的知识,做一些Demo,可以增加自己的亮点。
项目
实习项目:搞清楚参与系统的全貌(架构设计、核心技术点等)、梳理自己做的事情、多总结、也可从其他项目中吸取经验。
自学项目:不要纠结这个项目被多少人做过、说过。你要做的是通过这项目巩固自己的基础知识,其次能够在项目开发的时候多一些思考,多想一个为什么?而不是敲完代码就完事 了。项目中涉及的知识点是不是都会了?业务点能不能加一些个人的理解。
其他
1、工具:Maven/Gradle、Git Docker 等工具肯定也是要会的,相对来说面试问的很少, 根据自己的时间去做学习安排。
2、智能题:有时候你和面试官约的是电话面试,不方面写代码,那就可能是个智力题吧。如果在面试的时候你遇到了智力题,它的重要性和算法是一样的,打不出来,大概率 GG。
3、场景题:这类题目在面试时也是非常常见的,比如:你给我设计一个秒杀系统?百度搜索提示是如何实现的?等等。这类题目需要结合基础知识以及项目经验综合去回答。