写点什么

2024 年最新 Java 面试八股文总结,让你少走 99% 的弯路

作者:采菊东篱下
  • 2024-11-21
    湖南
  • 本文字数:4529 字

    阅读完需:约 15 分钟

开篇小叙

现在 Java 面试可以说是老生常谈的一个问题了,确实也是这么回事。面试题、面试宝典、面试手册......各种 Java 面试题一搜一大把,根本看不完,也看不过来,而且每份面试资料也都觉得 Nice,然后就开启了收藏之路。

Java 开发者应该是不会很容易满足的,现在拿着 20K 的工作,下一步就想着拿 50K 的 offer,甚至年薪百万都是程序员很常见的,不满足于现状,身在其位就要有担当其位的能力,不断提升技能、技术栈,都是必不可少的!

其实很多人,对本身没有一个清楚的规划,甚至不知道适合什么路线,这样的话,你就会离心仪的 offer 越来越远!无论何时,都需要对自身有一个清楚的认知,你会提前规划一下自己的学习路线吗?



那么我这次写这个的意义何在呢?不妨停下来,来看一下。可以更加系统、有条理地去复习,备战面试。有以下目的:

  • 可以通过一个体系进行复习,解决不知从哪里看起,如何下手?

  • 建立起一个系统的复习体系,每个知识点都是独立且有联系的?

  • 回顾并总结各大厂常考面试点,从自己的实际出发,了解差距在哪?

当然除了这些还有一部分很漂亮的学习资料,总结得很全面的,包含了 29 个知识点,从基础到进阶都有了!由于文档内容过多,因此为了避免影响到大家的阅读体验,在此只以截图展示部分内容,需要完整版的小伙伴可以点击这里即可获取到文章中的文档,资料!

JavaOOP

  • 什么是 B/S 架构?什么是 C/S 架构

  • Java 都有哪些开发平台?

  • 什么是 JDK?什么是 JRE?

  • Java 语言有哪些特点

  • 面向对象和面向过程的区别

  • 什么是数据结构?

  • Java 的数据结构有哪些?

  • 什么是 OOP?

  • 类与对象的关系?

  • Java 中有几种数据类型



Java 集合/泛型

  • ArrayList 和 linkedList 的区别

  • HashMap 和 HashTable 的区别

  • Collection 包结构,与 Collections 的区别

  • 泛型常用特点 (待补充)

  • 说说 List,Set,Map 三者的区别

  • Array 与 ArrayList 有什么不一样?

  • Map 有什么特点

  • 集合内存放于 Java.util 包中, 主要有几 种接口

  • 什么是 list 接口

  • 说说 ArrayList(数组)



Java 异常

  • Java 中异常分为哪两种?

  • 异常的处理机制有几种?

  • 如何自定义一个异常

  • try catch fifinally,try 里有 return,finally 还执行么?

  • Excption 与 Error 包结构

  • Thow 与 thorws 区别

  • Error 与 Exception 区别?

  • error 和 exception 有什么区别



Java 中的 IO 与 NIO

  • Java 中 IO 流?

  • Java IO 与 NIO 的区别

  • 常用 io 类有哪些

  • 字节流与字符流的区别

  • 阻塞 IO 模型

  • 非阻塞 IO 模型

  • 多路复用 IO 模型

  • 信号驱动 IO 模型

  • 异步 IO 模型

  • JAVA NIO



Java 反射

  • 除了使用 new 创建对象之外,还可以用什么方法创建对象?

  • Java 反射创建对象效率高还是通过 new 创建对象的效率高?

  • java 反射的作用

  • 哪里会用到反射机制?

  • 反射的实现方式:

  • 实现 Java 反射的类:

  • 反射机制的优缺点:

  • Java 反射 API

  • 反射使用步骤(获取 Class 对象、调用对象方法)

  • 获取 Class 对象有几种方法

  • 利用反射动态创建对象实例



Java 序列化

  • 什么是 java 序列化,如何实现 java 序列化?

  • 保存(持久化)对象及其状态到内存或者磁盘

  • 序列化对象以字节数组保持-静态成员不保存

  • 序列化用户远程对象传输

  • Serializable 实现序列化

  • writeObject 和 readObject 自定义序列化策略

  • 序列化 ID

  • 序列化并不保存静态变量

  • Transient 关键字阻止该变量被序列化到文件中

  • 序列化(深 clone 一中实现)



多线程 &并发

JAVA 并发知识库

  • Java 中实现多线程有几种方法

  • 继承 Thread 类

  • 实现 Runnable 接口。

  • ExecutorService、 Callable、 Future 有返回值线程

  • 基于线程池的方式

  • 4 种线程池

  • 如何停止一个正在运行的线程

  • notify()和 notifyAll()有什么区别?

  • sleep()和 wait() 有什么区别?

  • volatile 是什么?可以保证有序性吗?



JVM

  • java 中会存在内存泄漏吗,请简单描述。

  • 64 位 JVM 中,int 的长度是多数?

  • Serial 与 Parallel GC 之间的不同之处?

  • 32 位和 64 位的 JVM,int 类型变量的长度是多数?

  • Java 中 WeakReference 与 SoftReference 的区别?

  • JVM 选项 -XX:+UseCompressedOops 有什么作用?为什么要使用

  • 怎样通过 Java 程序来判断 JVM 是 32 位 还是 64 位?

  • 32 位 JVM 和 64 位 JVM 的最大堆内存分别是多数?

  • JRE、JDK、JVM 及 JIT 之间有什么不同?

  • 解释 Java 堆空间及 GC?



Mysql

  • 数据库存储引擎

  • InnoDB(B+树)

  • TokuDB( Fractal Tree-节点带数据)

  • Memory

  • 数据库引擎有哪些

  • InnoDB 与 MyISAM 的区别

  • 索引

  • 常见索引原则有

  • 数据库的三范式是什么

  • 第一范式(1st NF - 列都是不可再分)



Redis

  • 什么是 Redis?

  • Redis 与其他 key-value 存储有什么不同?

  • Redis 的数据类型?

  • 使用 Redis 有哪些好处?

  • Redis 相比 Memcached 有哪些优势?

  • Memcache 与 Redis 的区别都有哪些?

  • Redis 是单进程单线程的?

  • 一个字符串类型的智能存储最大容量是多少?

  • Redis 持久化机制

  • 缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题



Memcached

  • Memcached 是什么,有什么作用?

  • memcached 服务在企业集群架构中有哪些应用场景?

  • Memcached 服务分布式集群如何实现?

  • Memcached 服务特点及工作原理是什么?

  • 简述 Memcached 内存管理机制原理?

  • memcached 是怎么工作的?

  • memcached 最大的优势是什么?

  • memcached 和 MySQL 的 query

  • memcached 和服务器的 local cache(比如 PHP 的 APC、mmap 文件等)相比,有什么优缺点?

  • memcached 的 cache 机制是怎样的?

  • memcached 如何实现冗余机制?



MongoDB

  • mongodb 是什么?

  • mongodb 有哪些特点?

  • 你说的 NoSQL 数据库是什么意思?NoSQL 与 RDBMS 直接有什么区别?为什么要使用和不使用 NoSQL 数据库?说一说 NoSQL 数据库的几个优点?

  • NoSQL 数据库有哪些类型?

  • MySQL 与 MongoDB 之间最基本的差别是什么?

  • 你怎么比较 MongoDB、CouchDB 及 CouchBase?

  • MongoDB 成为最好 NoSQL 数据库的原因是什么?

  • journal 回放在条目(entry)不完整时(比如恰巧有一个中途故障了)会遇到问题吗?

  • 分析器在 MongoDB 中的作用是什么?

  • 名字空间(namespace)是什么?



Spring

  • 不同版本的 Spring Framework 有哪些主要功能?

  • 什么是 Spring Framework?

  • 列举 Spring Framework 的优点。

  • Spring Framework 有哪些不同的功能?

  • Spring Framework 中有多少个模块,它们分别是什么?

  • 什么是 Spring 配置文件?

  • Spring 应用程序有哪些不同组件?

  • 使用 Spring 有哪些方式?

  • 什么是 Spring IOC 容器?

  • 什么是依赖注入?



Spring Boot

  • 什么是 Spring Boot?

  • 为什么要用 SpringBoot

  • Spring Boot 有哪些优点?

  • Spring Boot 的核心注解是哪个?它主要由哪几个注解组成的?

  • 运行 Spring Boot 有哪几种方式

  • 如何理解 Spring Boot 中的 Starters?

  • 如何在 Spring Boot 启动的时候运行一些特定的代码?

  • Spring Boot 需要独立的容器运行吗?

  • Spring Boot 中的监视器是什么?

  • 如何使用 Spring Boot 实现异常处理?



Spring Cloud

  • 什么是 Spring Cloud?

  • 使用 Spring Cloud 有什么优势?

  • 服务注册和发现是什么意思?Spring Cloud 如何实现?

  • 负载平衡的意义什么?

  • 什么是 Hystrix?它如何实现容错?

  • 什么是 Hystrix 断路器?我们需要它吗?

  • 什么是 Netflix Feign?它的优点是什么?

  • 什么是 Spring Cloud Bus?我们需要它吗?

  • 什么是微服务

  • 什么是服务熔断?什么是服务降级



RabbitMQ

  • 什么是 rabbitmq

  • 为什么要使用 rabbitmq

  • 使用 rabbitmq 的场景

  • 如何确保消息正确地发送至 RabbitMQ? 如何确保消息接收方消费了消息?

  • 如何避免消息重复投递或重复消费?

  • 消息基于什么传输?

  • 消息如何分发?

  • 消息怎么路由?

  • 如何确保消息不丢失?

  • 使用 RabbitMQ 有什么好处?



Dubbo

  • 为什么要用 Dubbo?

  • Dubbo 的整体架构设计有哪些分层?

  • 默认使用的是什么通信框架,还有别的选择吗?

  • 服务调用是阻塞的吗?

  • 一般使用什么注册中心?还有别的选择吗?

  • 默认使用什么序列化框架,你知道的还有哪些?

  • 服务提供者能实现失效提出是什么原理?

  • 服务上线怎么不影响旧版本?

  • 如何解决服务调用链过长的问题?

  • 说说核心的配置有哪些?



MyBatis

  • 什么是 Mybatis?

  • Mybaits 的优点

  • MyBatis 框架的缺点

  • MyBatis 框架适用场合

  • MyBatis 与 Hibernate 有哪些不同?

  • #{}和 ${}的区别是什么?

  • 当实体类中的属性名和表中的字段名不一样 ,怎么办 ?

  • 模糊查询 like 语句该怎么写?

  • 通常一个 Xml 映射文件,都会写一个 Dao 接口与之对应,请问,这个 Dao 接口的工作原理是什么?Dao 接口里的方法,参数不同时,方法能重载吗?

  • 如何获取自动生成的(主)键值?



ZooKeeper

  • 什么是 Zookeeper?

  • Zookeeper 如何保证了分布式一致性特性?

  • ZooKeeper 提供了什么?

  • Zookeeper 文件系统

  • ZAB 协议?

  • 四种类型的数据节点 Znode

  • Zookeeper Watcher 机制 -- 数据变更通知

  • 客户端注册 Watcher 实现

  • 服务端处理 Watcher 实现

  • 客户端回调 Watcher



数据结构

  • 栈(stack)

  • 队列(queue)

  • 链表(Link)

  • 散列表(Hash Table)

  • 排序二叉树

  • 前缀树

  • 红黑树

  • B-TREE

  • 位图



Elasticsearch

  • elasticsearch 了解多少,说说你们公司 es 的集群架构,索引数据大小,分片有多少,以及一些调优手段 。

  • elasticsearch 的倒排索引是什么

  • elasticsearch 索引数据多了怎么办,如何调优,部署

  • elasticsearch 是如何实现 master 选举的

  • 详细描述一下 Elasticsearch 索引文档的过程

  • 详细描述一下 Elasticsearch 搜索的过程?

  • Elasticsearch 在部署时,对 Linux 的设置有哪些优化方法

  • lucence 内部结构是什么?

  • Elasticsearch 是如何实现 Master 选举的?

  • Elasticsearch 中的节点(比如共 20 个),其中的 10 个选了一个 master,另外 10 个选了另一个 master,怎么办?



Kafka

  • Kafka 是什么

  • partition 的数据文件(offset, MessageSize, data)

  • 数据文件分段 segment(顺序读写、分段命令、二分查找)

  • 负载均衡(partition 会均衡分布到不同 broker 上)

  • 批量发送

  • 压缩(GZIP 或 Snappy)

  • 消费者设计

  • Consumer Group

  • 如何获取 topic 主题的列表

  • 生产者和消费者的命令行是什么?



微服务

  • 微服务架构有哪些优势?

  • 微服务有哪些特点?

  • 设计微服务的最佳时间是什么?

  • 微服务架构如何运作?

  • 微服务架构的优缺点是什么?

  • 单片,SOA 和微服务架构有什么区别?

  • 在使用微服务架构时,您面临哪些挑战?

  • SOA 和微服务架构之间的主要区别是什么?

  • 微服务有什么特点?



Linux

  • 绝对路径用什么符号表示?当前目录、上层目录用什么表示?主目录用什么表示? 切换目录用什么命令?

  • 怎么查看当前进程?怎么执行退出?怎么查看当前路径?

  • 怎么清屏?怎么退出当前命令?怎么执行睡眠?怎么查看当

  • Ls 命令执行什么功能? 可以带哪些参数,有什么区别?

  • 查看文件有哪些命令

  • 列举几个常用的 Linux 命令

  • 你平时是怎么查看日志的?

  • 建立软链接(快捷方式),以及硬链接的命令

  • 目录创建用什么命令?创建文件用什么命令?复制文件用什么命令?

  • 查看文件内容有哪些命令可以使用?



面试,难还是不难?最终结果好还是不好?取决于面试者的底蕴(气场+技能)、心态和认知以及沟通技巧。而一些主流的大型互联网公司面试(阿里巴巴、京东、美团、滴滴)更是需要你在面试时展现出自己的能力,从而获得面试官的欣赏和肯定。

而程序员在应聘时更是需要经历层层面试。俗话说,磨刀不误砍柴工,做好面试前的准备工作可以帮助大家更好的应对面试官的问题以及面试中的突发情况。

由于篇幅限制小编,pdf 文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容


如何获取免费架构学习资料?

Ps:由于篇幅限制,笔记无法全部为大家展示出来,就以截图主要内容的形式让大家参考啦,需要完整版的小伙伴可以点击这里即可获取到文章中的文档,资料!







用户头像

还未添加个人签名 2023-02-14 加入

还未添加个人简介

评论

发布
暂无评论
2024年最新Java面试八股文总结,让你少走99%的弯路_java面试_采菊东篱下_InfoQ写作社区