【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路

跳槽是每个人的职业生涯中都要经历的过程,不论你是搜索到的这篇文章还是无意中浏览到的这篇文章,希望你没有白白浪费停留在这里的时间,能给你接下来或者以后的笔试面试带来一些帮助。

2022或许是近几年来程序员最艰难的一年,现在疫情已经慢慢减少了,WINTER IS COMING。但是如果你不真正的自己去尝试尝试,你永远不知道市面上的行情如何。这次找工作下来,我自身感觉市场并没有那么可怕,也拿到了几个大厂的offer。在此进行一个总结,给自己,也希望能帮助到需要的码友们。

小编为大伙新整理了一份面试复习资料,希望可以帮到你们哦~

包括:基础、集合框架、JVM、Java多线程、MySQL、Redis、Spring、消息队列、Dubbo、算法、设计模式、数据库、网络协议、Linux系统、计算机原理等等相关知识点...以及BATJ真实面试题

本文档提供详细的目录,大家可以根据自己的实际需要选择自己薄弱的知识参考阅读

Java 基础知识

  • 重载和重写的区别
  • String 和 StringBuffer、StringBuilder 的区别是什么?String 为什么是不可变的?
  • 自动装箱与拆箱
  • Java 中的异常处理
  • 接口和抽象类的区别是什么
  • Object类的常见方法
  • 获取用键盘输入常用的的两种方法

    【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第1张图片

    Java 集合框架

  • Arraylist 与 LinkedList 异同
  • ArrayList 与 Vector 区别
  • HashMap的底层实现
  • HashMap 和 Hashtable 的区别
  • HashMap 的长度为什么是2的幂次方
  • HashMap 多线程操作导致死循环问题
  • HashSet 和 HashMap 区别
  • ConcurrentHashMap 和 Hashtable 的区别
  • ConcurrentHashMap线程安全的具体实现方式/底层具体实现
  • 集合框架底层数据结构

【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第2张图片

Java多线程

面试官在多线程这一部分很可能会问你有没有在项目中实际使用多线程的经历。所以,如果你在你的项目中有实际使用Java多线程的经历 的话,会为你加分不少哦!
  • 说一说自己对于 synchronized 关键字的了解
  • 说说自己是怎么使用 synchronized 关键字,在项目中用到了吗
  • 讲一下 synchronized 关键字的底层原理
  • 说说 JDK1.6 之后的synchronized 关键字底层做了哪些优化,可以详细介绍一下这些优化吗
  • 谈谈 synchronized和ReenTrantLock 的区别
  • 说说 synchronized 关键字和 volatile 关键字的区别
  • 为什么要用线程池?
  • 实现Runnable接口和Callable接口的区别
  • 执行execute()方法和submit()方法的区别是什么呢?
  • 如何创建线程池
  • 介绍一下Atomic 原子类
  • JUC 包中的原子类是哪4类?
  • 讲讲 AtomicInteger 的使用
  • 能不能给我简单介绍一下 AtomicInteger 类的原理

【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第3张图片

JVM

JVM的设计目标是提供一个基于抽象规格描述的计算机模型,为解释程序开发人员提供很好的灵活性,同时也确保Java代码可在符合该规范的任何系统上运行。JVM对其实现的某些方面给出了具体的定义,特别是对Java可执行代码,即字节码(Bytecode)的格式给出了明确的规格。这一规格包括操作码和操作数的语法和数值、标识符的数值表示方式、以及Java类文件中的Java对象、常量缓冲池在JVM的存储映象。这些定义为JVM解释器开发人员提供了所需的信息和开发环境。Java的设计者希望给开发人员以随心所欲使用Java的自由。
  • 内存模型以及分区,需要详细到每个区放什么。
  • GC 收集器有哪些?CMS 收集器与 G1 收集器的特点。
  • Minor GC 与 Full GC 分别在什么时候发生?
  • 堆里面的分区:Eden,survival (from+ to),老年代,各自的特点。
  • 简述 java 垃圾回收机制?
  • java 中垃圾收集的方法有哪些?
  • 类加载器双亲委派模型机制?什么是类加载器,类加载器有哪些?
  • 简述 java 内存分配与回收策率以及 Minor GC 和Major GC

【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第4张图片

网络协议

  • TCP、UDP 协议的区别
  • 在浏览器中输入url地址 ->> 显示主页的过程
  • 各种协议与HTTP协议之间的关系
  • HTTP长连接、短连接
  • TCP 三次握手和四次挥手(面试常客)

【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第5张图片

MySQL

MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。

  • Mysql 的技术特点是什么?
  • MYSQL 数据表在什么情况下容易损坏?
  • 说说自己对于 MySQL 常见的两种存储引擎:MyISAM与InnoDB的理解
  • 数据库索引了解吗?
  • 能说下MySQL 的基本存储结构吗?
  • Mysql如何为表字段添加索引?
  • 对于大表的常见优化手段说一下
  • mysql 里记录货币用什么字段类型好
  • 当MySQL单表记录数过大时,数据库的CRUD性能会明显下降,有哪些常见的优化措施?

【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第6张图片

Redis

简单来说 redis 就是一个数据库,不过与传统数据库不同的是 redis 的数据是存在内存中的,所以存写速度非常快,因此 redis 被广泛应用于缓存方向。另外,redis 也经常用来做分布式锁。redis 提供了多种数据类型来支持不同的业务场景。除此之外,redis 支持事务 、持久化、LUA脚本、LRU驱动事件、多种集群方案。
  • 为什么要用 redis /为什么要用缓存?
  • 为什么要用 redis 而不用 map/guava 做缓存?
  • redis 和 memcached 的区别?
  • 上述 Redis 分布式锁的缺点?
  • redis 常见数据结构以及使用场景分析
  • redis 内存淘汰机制(MySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据?)
  • redis 持久化机制(怎么保证 redis 挂掉之后再重启数据可以进行恢复)?
  • 缓存雪崩和缓存穿透问题解决方案?
  • 如何解决 Redis 的并发竞争 Key 问题?
  • 如何保证缓存与数据库双写时的数据一致性?

【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第7张图片

Spring

Spring一般是不可避免的,如果你的简历上注明了你会Spring Boot或者Spring Cloud的话,那么面试官也可能会同时问你这两个技术,比如他可能会问你springboot和spring的区别。 所以,一定要谨慎对待写在简历上的东西,一定要对简历上的东西非常熟悉。

另外,AOP实现原理、动态代理和静态代理、Spring IOC的初始化过程、IOC原理、自己怎么实现一个IOC容器? 这些东西都是经常会被问到的。

  • Spring Bean 的作用域?
  • 如何用基于 Java 配置的方式配置 Spring?
  • 请说下 Spring Bean 的生命周期?
  • Spring Bean 的作用域之间有什么区别?
  • 请举例说明如何在 Spring 中注入一个 Java Collection?
  • Spring 框架中有哪些不同类型的事件?
  • Spring 框架中都用到了哪些设计模式?
  • 开发中主要使用 Spring 的什么技术 ?

【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第8张图片

消息队列

“RabbitMQ?”“Kafka?”“RocketMQ?”...在日常学习与开发过程中,我们常常听到消息队列这个关键词。这也是面试经常被问到的
  • 什么是消息队列?
  • 为什么要用消息队列?丢消息怎么办?
  • 如何解决消息重复问题?
  • ActiveMQ 中的消息重发时间间隔和重发次数吗?
  • ActiveMQ 服务器宕机怎么办?
  • ActiveMQ 如何调优?
  • Basic.Reject 的用法是什么?
  • 为什么不应该对所有的 message 都使用持久化机制?
  • 为什么 heavy RPC 的使用场景下不建议采用 disk node ?

【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第9张图片

Dubbo

Dubbo 是由阿里开源,后来加入了 Apache 。正式由于 Dubbo 的出现,才使得越来越多的公司开始使用以及接受分布式架构,所以面试时也是经常被问到的
  • 什么是 Dubbo?
  • 什么是 RPC?RPC原理是什么?
  • 为什么要用 Dubbo?
  • 什么是分布式?为什么要分布式?
  • 先来解释一下什么是负载均衡?
  • Dubbo 集群提供了哪些负载均衡策略?
  • Dubbo 支持哪些协议,每种协议的应用场景,优缺点?
  • Dubbo 的集群容错方案有哪些?
  • Dubbo 和 Spring Cloud 的关系?

    【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第10张图片

数据结构

数据结构比较常问的就是:二叉树、红黑树(很可能让你手绘一个红黑树出来哦!)、二叉查找树(BST)、平衡二叉树(Self-balancing binary search tree)、B-树,B+树与B*树的优缺点比较、 LSM 树这些知识点。

数据结构很重要,而且学起来也相对要难一些。建议学习数据结构一定要循序渐进的来,一步一个脚印的走好。一定要搞懂原理,最好自己能用代码实现一遍。

  • 什么是队列
  • 说下什么是队列的种类
  • 什么是 Set?说下HashSet 和 TreeSet 底层数据结构
  • 什么是List?List的常见实现类是什么?

【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第11张图片

Linux

在Linux操作系统中,所有被操作系统管理的资源,例如网络接口卡、磁盘驱动器、打印机、输入输出设备、普通文件或是目录都被看作是一个文件。

也就是说在LINUX系统中有一个重要的概念:一切都是文件。其实这是UNIX哲学的一个体现,而Linux是重写UNIX而来,所以这个概念也就传承了下来。在UNIX系统中,把一切资源都看作是文件,包括硬件设备。UNIX系统把每个硬件都看成是一个文件,通常称为设备文件,这样用户就可以用读写文件的方式实现对硬件的访问。

  • 简单介绍一下 Linux 文件系统?
  • 一些常见的 Linux 命令了解吗?
  • Linux 中主要有哪几种内核锁?
  • Linux 中的用户模式和内核模式是什么含意?
  • 用户进程间通信主要哪几种方式?
  • 通过伙伴系统申请内核内存的函数有哪些?
  • 模块程序能否使用可链接的库函数?
  • Linux 通过什么方式实现系统调用?
  • Linux 软中断和工作队列的作用是什么?

【Java后端开发岗】从20k跳槽到35k公司,讲述一下自己的复习之路_第12张图片

我个人觉得面试也像是一场全新的征程,失败和胜利都是平常之事。所以,劝各位不要因为面试失败而灰心、丧失斗志。也不要因为面试通过而沾沾自喜,等待你的将是更美好的未来,继续加油!

由于篇幅限制小编,以上面试专题答案全部整理在一个pdf文档里了,
文档里的详解资料太全面,所以只把部分知识点截图出来粗略的介绍,
每个小节点里面都有更细化的内容!
有需要的小伙伴可以帮忙点赞之后私信03免费获取!

你可能感兴趣的:(后端,面试,架构,java,面试,开发语言,mysql,数据库)