【2020Java秋招学习历程】

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 【2020Java秋招学习历程】

本文主要记录题主备战秋招及秋招经过的帖子




编程语言

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、场景题:这类题目在面试时也是非常常见的,比如:你给我设计一个秒杀系统?百度搜索提示是如何实现的?等等。这类题目需要结合基础知识以及项目经验综合去回答。


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
18天前
|
消息中间件 前端开发 Java
java学习路径
【4月更文挑战第9天】java学习路径
17 1
|
1月前
|
安全 Java 程序员
学习Java类加载机制
在Java的世界里,每一个类或者接口,在经历编译器后,都会生成一个个.class文件。
18 0
|
18天前
|
设计模式 前端开发 安全
Java是一种广泛使用的编程语言,其学习路径可以大致分为以下几个阶段
【4月更文挑战第9天】Java是一种广泛使用的编程语言,其学习路径可以大致分为以下几个阶段
15 1
|
1月前
|
Java 索引
Java中String方法学习总结_kaic
Java中String方法学习总结_kaic
|
3天前
|
Java Nacos 开发者
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
|
3天前
|
Dubbo Java 应用服务中间件
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
|
3天前
|
SQL Java 数据库连接
Java从入门到精通:2.3.1数据库编程——学习JDBC技术,掌握Java与数据库的交互
ava从入门到精通:2.3.1数据库编程——学习JDBC技术,掌握Java与数据库的交互
|
3天前
|
设计模式 存储 前端开发
Java从入门到精通:2.2.1学习Java Web开发,了解Servlet和JSP技术,掌握MVC设计模式
Java从入门到精通:2.2.1学习Java Web开发,了解Servlet和JSP技术,掌握MVC设计模式
|
3天前
|
Java API
Java从入门到精通:2.1.5深入学习Java核心技术之文件操作
Java从入门到精通:2.1.5深入学习Java核心技术之文件操作
|
3天前
|
并行计算 算法 安全
Java从入门到精通:2.1.3深入学习Java核心技术——掌握Java多线程编程
Java从入门到精通:2.1.3深入学习Java核心技术——掌握Java多线程编程