2023最新最全面Java复习路线(含P5-P8),已收录 GitHub

news2024/11/25 23:42:48

小编整理出一篇 Java 进阶架构师之路的核心知识,同时也是面试时面试官必问的知识点,篇章也是包括了很多知识点,其中包括了有基础知识、Java 集合、JVM、多线程并发、spring 原理、微服务、Netty 与 RPC 、Kafka、日记、设计模式、Java 算法、数据库、Zookeeper、分布式缓存、数据结构等等

由于 pdf 文档里的细节内容实在过多所以只编辑了部分知识点的章节粗略的介绍下,每个章节小节点里面都有更细化的内容!以下就是部分章节目录

JVM

  1. 线程
  2. JVM 内存区域
  3. JVM 运行时内存
  4. 垃圾回收与算法
  5. JAVA 四中引用类型
  6. GC 分代收集算法 VS 分区收集算法
  7. GC 垃圾收集器
  8. JAVA IO/NIO
  9. JVM 类加载机制

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

JAVA 集合

  1. 接口继承关系和实现
  2. List
  3. ArrayList(数组)
  4. Vector(数组实现、线程同步)
  5. LinkList(链表)
  6. Set
  7. HashSet(Hash 表)
  8. TreeSet(二叉树)

JAVA 多线程并发

  1. JAVA 并发知识库
  2. JAVA 线程实现/创建方式
  3. 4 种线程池
  4. 线程生命周期(状态)
  5. 终止线程 4 种方式
  6. sleep 与 wait 区别
  7. start 与 run 区别
  8. JAVA 后台线程
  9. JAVA 锁
  10. 线程基本方法 4.1.11. 线程上下文切换
  11. 同步锁与死锁
  12. 线程池原理
  13. JAVA 阻塞队列原理
  14. CyclicBarrier、CountDownLatch、Semaphore 的用法
  15. volatile 关键字的作用(变量可见性、禁止重排序)
  16. 如何在两个线程之间共享数据

JAVA 基础

  1. JAVA 异常分类及处理
  2. JAVA 反射
  3. JAVA 注解
  4. JAVA 内部类
  5. JAVA 泛型
  6. JAVA 序列化(创建可复用的 Java 对象)
  7. JAVA 复制

Spring 原理

  1. Spring 特点
  2. Spring 核心组件
  3. Spring 常用模块
  4. Spring 主要包
  5. Spring 常用注解
  6. Spring 第三方结合
  7. Spring IOC 原理
  8. Spring APO 原理
  9. Spring MVC 原理
  10. Spring Boot 原理
  11. JPA 原理
  12. Mybatis 缓存
  13. Tomcat 架构

微服务

  1. 服务注册发现
  2. API 网关
  3. 配置中心
  4. 事件调度(kafka)
  5. 服务跟踪(starter-sleuth)
  6. 服务熔断(Hystrix)
  7. Hystrix 断路器机制
  8. API 管理

Netty 与 RPC

  1. Netty 原理
  2. Netty 高性能
  3. Netty RPC 实现
  4. 关键技术
  5. 核心流程
  6. 消息编解码
  7. 通讯过程
  8. RMI 实现方式

分布式缓存

  1. 缓存雪崩
  2. 缓存穿透
  3. 缓存预热
  4. 缓存更新
  5. 缓存降级

网络

  1. 网络 7 层架构
  2. TCP/IP 原理
  3. TCP 三次握手/四次挥手
  4. HTTP 原理
  5. CDN 原理
  6. 分发服务系统
  7. 负载均衡系统
  8. 管理系统

日志

  1. Slf4j
  2. Log4j
  3. LogBack
  4. Logback 优点
  5. ELK

Zookeeper

  1. Zookeeper 概念
  2. Zookeeper 角色
  3. Zookeeper 工作原理(原子广播)
  4. Znode 有四种形式的目录节点

Kafka

  1. Kafka 概念
  2. Kafka 数据存储设计
  3. partition 的数据文件(offset,MessageSize,data)
  4. 数据文件分段 segment(顺序读写、分段命令、二分查找)
  5. 数据文件索引(分段索引、稀疏存储)
  6. 生产者设计
  7. 负载均衡(partition 会均衡分布到不同 broker 上)
  8. 批量发送
  9. 压缩(GZIP 或 Snappy)
  10. 消费者设计

RabbitMQ

  1. RabbitMQ 概念
  2. RabbitMQ 架构
  3. Exchange 类型

Hbase

  1. Hbase 概念
  2. 列式存储
  3. Hbase 核心概念
  4. Hbase 核心架构
  5. Hbase 的写逻辑
  6. HBase vs Cassandra
  7. MongoDB
  8. MongoDB 概念
  9. MongoDB 特点

Cassandra

  1. Cassandra 概念
  2. 数据模型
  3. Cassandra 一致 Hash 和虚拟节点
  4. Gossip 协议
  5. 数据复制
  6. 数据写请求和协调者
  7. 数据读请求和后台修复
  8. 数据存储(CommitLog、MemTable、SSTable)
  9. 二级索引(对要索引的 value 摘要,生成 RowKey)
  10. 数据读写

设计模式

  1. 设计原则
  2. 工厂方法模式
  3. 抽象工厂模式
  4. 单例模式
  5. 建造者模式
  6. 原型模式
  7. 适配器模式
  8. 装饰器模式
  9. 代理模式
  10. 外观模式
  11. 桥接模式
  12. 组合模式
  13. 享元模式
  14. 策略模式
  15. 模板方法模式
  16. 观察者模式
  17. 迭代子模式
  18. 责任链模式
  19. 命令模式
  20. 备忘录模式

负载均衡

  1. 四层负载均衡 vs 七层负载均衡
  2. 负载均衡算法/策略
  3. LVS
  4. Keepalive
  5. Nginx 反向代理负载均衡
  6. HAProxy

数据库

  1. 存储引擎
  2. 索引
  3. 数据库三范式
  4. 数据库是事务
  5. 存储过程(特定功能的 SQL 语句集)
  6. 触发器(一段能自动执行的程序)
  7. 数据库并发策略
  8. 数据库锁
  9. 基于 Redis 分布式锁
  10. 分区分表
  11. 两阶段提交协议
  12. 三阶段提交协议
  13. 柔性事务
  14. CAP

一致性算法

  1. Paxos
  2. Zab
  3. Raft
  4. NWR
  5. Gossip
  6. 一致性 Hash
  7. 一致性 Hash 特性
  8. 一致性 Hash 原理

JAVA 算法

  1. 二分查找
  2. 冒泡排序算法
  3. 插入排序算法
  4. 快速排序算法
  5. 希尔排序算法
  6. 归并排序算法
  7. 桶排序算法
  8. 基数排序算法
  9. 剪枝算法
  10. 回溯算法
  11. 最短路径算法
  12. 最大子数组算法
  13. 最长公共子序算法
  14. 最小生成树算法

数据结构

  1. 栈(stack)
  2. 队列(queue)
  3. 链表(Link)
  4. 散列表(Hash Table)
  5. 排序二叉树
  6. 红黑树
  7. B-TREE
  8. 位图

加密算法

  1. AES
  2. RSA
  3. CRC
  4. MD5

Hadoop

  1. Hadoop 概念
  2. HDFS
  3. Client
  4. NameNode
  5. Secondary NameNode
  6. DataNode
  7. MapReduce
  8. JobTracker
  9. TaskTracker
  10. Task
  11. Reduce Task 执行过程
  12. Hadoop MapReduce 作业的生命周期
  13. 作业提交与初始化
  14. 任务调度与监控。
  15. 任务运行环境准备
  16. 任务执行
  17. 作业完成

Spark

  1. Spark 概念
  2. 核心架构
  3. 核心组件
  4. SPARK 编程模型
  5. SPARK 计算模型
  6. SPARK 运行流程
  7. SPARK RDD 流程
  8. SPARK RDD

Storm

  1. Storm 概念
  2. 集群架构
  3. Nimbus(master-代码分发给 Supervisor)
  4. Supervisor(slave-管理 Worker 进程的启动和终止)
  5. Worker(具体处理组件逻辑的进程)
  6. Task
  7. ZooKeeper
  8. 编程模型(spout->tuple->bolt)
  9. opology 运行
  10. Storm Streaming Grouping
  11. ResourceManager
  12. NodeManager
  13. ApplicationMaster
  14. YARN 运行流程

云计算

  1. SaaS
  2. PaaS
  3. IaaS
  4. Docker
  5. Openstack
  6. Namespaces
  7. 进程(CLONE_NEWPID 实现的进程隔离)
  8. Libnetwork 与网络隔离
  9. 资源隔离与 CGroups
  10. 镜像与 UnionFS
  11. 存储驱动

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/629977.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SQLServer2022安装(Windows),已验证

一、SQLServer2022下载 1、官网下载地址 SQL Server 下载 | Microsoft 2、下载安装包 2.1、选择Developer版本,立即下载。 2.2、打开下载文件夹,双击运行SQL2022-SSEI-Dev.exe 尝试运行SQL2022-SSEI-Dev.exe,会收到以下信息:“…

3.Hive系列之docker-compose部署升级总结

1. 版本号修改 对于升级而言,我们最先考虑的是docker hub中有的较新的版本,然后我们需要简单了解下hadoop2与hadoop3的区别,首先明确的是端口号有所改变,如下图所示 2. Hive镜像构建 刚刚我们修改了Hive为bde2020/hive:3.1.2-po…

ESPG(European Petroleum Survey Group)

数据转换器(栅格) ,数据转换器(矢量)转换数据时经常会看到EPSG的坐标系标识。那么什么是EPSG呢? ESPG(European Petroleum Survey Group)坐标系是一种用于地球表面测量和地理信息处…

Xubuntu之将rm删除内容移至回收站(一百七十七)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 人生格言: 人生…

【小沐学Unity3d】Unity3d导入3D模型

文章目录 1、简介1.1 标准文件格式1.2 专有文件格式1.3 从 Autodesk 3ds Max 导入对象1.4 从 Blender 导入对象 2、测试2.1 新建项目2.2 导入fbx2.2 手动调整相机2.3 脚本控制相机 结语 1、简介 Unity 支持多种标准和专有模型文件格式。 Unity 内部使用 .fbx 文件格式作为其导…

【前端 - CSS】第 9 课 - CSS 初体验

欢迎来到博主 Apeiron 的博客,祝您旅程愉快 ! 时止则止,时行则行。动静不失其时,其道光明。 目录 1、CSS 定义 2、基础选择器 3、文字控制属性 4、示例代码 5、总结 1、CSS 定义 层叠样式表(Cascading Style …

IP组播6_PIM-SM(SSM)详解

目录 1.PIM-SM(SSM)简介 2.PIM-SM(ASM)工作原理 3.PIM-SM(SSM)实验 3.1 PIM-SM(SSM)常用配置命令 3.2 PIM-SM(ASM)实验配置步骤 3.3 PIM-SM&#xff08…

HTMLCSS Day01 功能元素与HTTP请求协议详解

文章目录 1.功能元素1.1.列表标签- HTML中列表标签的分类 1.1.1.无序列表:- 无序列表格式:- 无序列表样式- 注意点:- 无序列表应用场景: 1.1.2.有序列表- 有序列表格式:- 有序列表样式 1.1.3.定义列表- 定义列表的格式:- 定义列表的应用场景- 定义列表的注意点 1.2.表格标签- 什…

【算法】手写题

文章目录 画一个三角形实现三栏布局通过position和margin通过float和margin通过flex实现 变量提升题实现边框0.5px深拷贝快速排序手写发布订阅/事件总线 画一个三角形 .box1 {width: 0;height: 0;border: 10px solid;border-color: red transparent transparent transparent;}实…

window编写redis服务启动脚本

日常工作中,每次启动项目总会忘记开启redis服务,并收货一天中的第一个项目报错,然后经历繁琐的文件查找redis所在目录,并点击redis-server.exe,启动服务,于是笔者在想,如果在桌面写个脚本一键启…

新项目,不妨采用这种架构分层,很优雅

在专栏开篇提到过DDD(Domain-Driven Design,领域驱动设计)学习起来较为复杂,一方面因为其自身涉及的概念颇多,另一方面,我们往往缺乏实战经验和明确的代码模型指导。今天,我们将专注于DDD的分层…

机器学习笔记 - EANet 外部注意论文简读及代码实现

一、论文简述 论文作者提出了一种新的轻量级注意力机制,称之为外部注意力。如图所示,计算自注意力需要首先通过计算自查询向量和自关键字向量之间的仿射关系来计算注意力图,然后通过用该注意力图加权自值向量来生成新的特征图。外部关注的作用…

条款29:假定移动操作不存在、成本高、未使用

移动语义可以说在C11的所有语言特性中占据着首要中的首要地位。“移动容器现在和复制指针一样成本低廉了!”这是你很可能听说过的,类似说法还有“复制临时对象现在已经如此高效,如果刻意在撰写代码总避免它,就无异于犯了过早优化的…

java SSM 程序在线评判系统myeclipse开发mysql数据库springMVC模式java编程计算机网页设计

一、源码特点 java SSM 程序在线评判系统是一套完善的web设计系统(系统采用SSM框架进行设计开发,springspringMVCmybatis),对理解JSP java编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采…

PDCA循环

PDCA循环 由美国质量管理专家沃特阿曼德休哈特(Walter A. Shewhart)首先提出的,由戴明采纳、宣传,获得普及,所以又称戴明环。 模型介绍 戴明是一位美国的质量管理大师,却成名于日本。在他的帮助下&#xf…

JQuery 操作Class实现前段交互方案(推荐)

一、JQuery基础控制图片宽度实现动画交互 1.html页面声明周期 //页面生命周期 //页面的数据html,加载完成, 图片ajax视频 在异步加载中 //document.ready---DOMContentLoaded ----小程序onload ---Vue created() //页面加载完成 //window.onload…

二叉树的相关操作

一.二叉树 本文的数据结构基于C语言练习。 C语言中的二叉树是一种数据结构,用于表示具有层次关系的数据集合。它由一个根节点开始,每个节点最多有两个子节点,分别称为左子节点和右子节点。 二叉树有许多相关性质,其中一些重要的包…

记录一下idea黄色警戒线问题

记录一下idea黄色警戒线问题 一、通用文件中解决黄色波浪线问题1.选中File中的Settings进入2.点击Editor,选中Inspections,找到General,找到Dulicated code fragment点击取消 二、SQL文件中黄色警告线 一、通用文件中解决黄色波浪线问题 1.选…

jvm之7种垃圾回收器解读(下)

目录 G1回收器:区域化分代式 G1回收器的特点(优势) 空间整合 可预测的停顿时间模型(即:软实时soft real-time) G1垃圾收集器的缺点 G1回收器的参数设置 G1收集器的常见操作步骤 G1收集器的适用场景 分…

Spring SpringMVC Mybatis 整合 SSM整合 一篇就够了!

SSM详细整合教程 因为XML注解方式实现更加方便,所以我门选用它 文章目录 SSM详细整合教程一、整合思路二、整合步骤0. 前期准备引入Jar包与Web目录创建1. Spring框架编写1.1 创建Application配置文件 2. SpringMvc框架编写2.1 创建Springmvc-config文件2. 2 配置前端…