Spring全套教学资料
Spring是Java程序员的《葵花宝典》,其中提供的各种大招,能简化我们的开发,大大提升开发效率!目前99%的公司使用了Spring,大家可以去各大招聘网站看一下,Spring算是必备技能,所以一定要掌握。
目录:
部分内容:
Spring源码
- 第一部分 Spring 概述
- 第二部分 核心思想
- 第三部分 手写实现 IoC 和 AOP(自定义Spring框架)
- 第四部分 Spring IOC 高级应用
基础特性
高级特性 - 第五部分 Spring IOC源码深度剖析
设计优雅
设计模式
注意:原则、方法和技巧 - 第六部分 Spring AOP 应用
声明事务控制 - 第七部分 Spring AOP源码深度剖析
必要的笔记、必要的图、通俗易懂的语言化解知识难点
脚手框架:SpringBoot技术
它的目标是简化Spring应用和服务的创建、开发与部署,简化了配置文件,使用嵌入式web服务器,含有诸多开箱即用的微服务功能,可以和spring cloud联合部署。
Spring Boot的核心思想是约定大于配置,应用只需要很少的配置即可,简化了应用开发模式。
- SpringBoot入门
- 配置文件
- 日志
- Web开发
- Docker
- SpringBoot与数据访问
- 启动配置原理
- 自定义starter
微服务架构:Spring Cloud Alibaba
同 Spring Cloud 一样,Spring Cloud Alibaba 也是一套微服务解决方案,包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。
- 微服务架构介绍
- Spring Cloud Alibaba介绍
- 微服务环境搭建
- 服务治理
- 服务容错
- 服务网关
- 链路追踪
- ZipKin集成及数据持久化
- 消息驱动
- 短信服务
- Nacos Confifig—服务配置
- Seata—分布式事务
- Dubbo—rpc通信
Spring MVC
目录:
部分内容:
-
atomicinteger和volatile等线程安全操作的关键字的理解和使用
-
volatile 变量是什么?volatile 变量和 atomic 变量有什么不同?
-
当一个线程进入一个对象的一个 synchronized 方法后,其它线程是否可进入此对象的其它方法?
-
简述 synchronized 和 java.util.concurrent.locks.Lock 的异同?
-
多线程之间通信的同步问题,synchronized锁的是对象,衍伸出和synchronized相关很多的具体问题,例如同一个类不同方法都有synchronized锁,一个对象是否可以同时访问。或者一个类的static构造方法加上synchronized之后的锁的影响。
-
volatile 类型变量提供什么保证?能使得一个非原子操作变成原子操作吗?
-
了解可重入锁的含义,以及ReentrantLock 和synchronized的区别
-
Java创建线程之后,直接调用start()方法和run()的区别
-
同步的数据结构,例如concurrentHashMap的源码理解以及内部实现原理,为什么它是同步的且效率高
-
常用的线程池模式以及不同线程池的使用场景
-
newFixedThreadPool此种线程池如果线程数达到最大值后会怎么办,底层原理。
七、网络方面
======
-
为什么要三次握手
-
二次握手有什么问题
-
三次握手有哪些缺陷
-
TCP是如何控制流量的
-
发送方发送频率过高造成丢包,TCP是如何解决的
-
HTTPs为什么要用对称加密+非对称加密,相对于只使用非对称加密有什么好处
-
讲一下OSI网络架构
-
HTTP在哪一层
-
HTTP报文结构
-
HTTP首部字段
-
HTTPs加密在哪一层实现
-
http是无状态通信,http的请求方式有哪些,可以自己定义新的请求方式么。
-
socket通信,以及长连接,分包,连接异常断开的处理。
-
socket通信模型的使用,AIO和NIO。
-
socket框架netty的使用,以及NIO的实现原理,为什么是异步非阻塞
八、MySQL数据库
==========
-
务四大特性(ACID)原子性、一致性、隔离性、持久性?
-
查询语句不同元素(where、jion、limit、group by、having等等)执行先后顺序?
-
MySQL常见的三种存储引擎(InnoDB、MyISAM、MEMORY)的区别?
-
MySQL的MyISAM与InnoDB两种存储引擎在,事务、锁级别,各自的适用场景?
-
mysql 高并发环境解决方案?
-
事务的并发?事务隔离级别,每个级别会引发什么问题,MySQL默认是哪个级别?
-
MySQL B+Tree索引和Hash索引的区别?
-
有哪些锁(乐观锁悲观锁),select 时怎么加排它锁?
-
sql查询语句确定创建哪种类型的索引?如何优化查询?
-
聚集索引和非聚集索引区别?
-
mysql都有什么锁,死锁判定原理和具体场景,死锁怎么解决?
-
非关系型数据库和关系型数据库区别,优势比较?
-
MySQL慢查询怎么解决?
-
数据库的读写分离、主从复制,主从复制分析的 7 个问题?
-
数据库崩溃时事务的恢复机制(REDO日志和UNDO日志)?
九、Redis缓存
=========
-
redis事务相关命令有哪些?
-
为什么要用 redis /为什么要用缓存(高性能、高并发)
-
为什么要用 redis 而不用 map/guava 做缓存?
-
redis 和 memcached 的区别
-
请介绍一下Redis的数据类型SortedSet(zset)以及底层实现机制?
-
redis 常见数据结构以及使用场景分析(String、Hash、List、Set、Sorted Set)
-
redis 设置过期时间
-
redis 内存淘汰机制(MySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据?)
-
redis 持久化机制(怎么保证 redis 挂掉之后再重启数据可以进行恢复)
-
redis 事务
-
Redis 常见异常及解决方案(缓存穿透、缓存雪崩、缓存预热、缓存降级)
-
分布式环境下常见的应用场景(分布式锁、分布式自增 ID)
-
Redis 集群模式(主从模式、哨兵模式、Cluster 集群模式)
-
如何解决 Redis 的并发竞争 Key 问题
-
如何保证缓存与数据库双写时的数据一致性?
十、JVM相关
=======
-
如何判断一个对象是否存活?(或者 GC 对象的判定方法)
-
java 中垃圾收集的方法有哪些?
-
简述 java 垃圾回收机制?
-
GC 的两种判定方法?
-
Minor GC 与 Full GC 分别在什么时候发生?
-
JVM 内存分哪几个区,每个区的作用是什么?
-
GC 收集器有哪些?CMS 收集器与 G1 收集器的特点
-
GC 的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路?
-
类加载器双亲委派模型机制?
-
java 类加载过程?
-
简述 java 类加载机制?
-
什么是类加载器,类加载器有哪些?
-
简述 java 内存分配与回收策略以及 Minor GC 和Major GC
-
HotSpot 虚拟机对象探秘
-
HotSpot 垃圾收集器
十一、调优方面
=======
-
垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收?
-
Java 中会存在内存泄漏吗,请简单描述。
-
如果对象的引用被置为 null,垃圾收集器是否会立即释放对象占用的内存?
-
finalize() 方法什么时候被调用?析构函数 (finalization) 的目的是什么?
-
串行(serial)收集器和吞吐量(throughput)收集器的区别是什么?
-
什么是分布式垃圾回收(DGC)?它是如何工作的?
-
你怎样给 tomcat 去调优?
-
Tomcat 的优化经验
-
在 Java 中,对象什么时候可以被垃圾回收?
-
System.gc() 和 Runtime.gc() 会做什么事情?
-
Java 中会存在内存泄漏吗,请简单描述
-
GC 是什么? 为什么要有 GC?
-
JVM 的永久代中会发生垃圾回收么?
-
tomcat 有哪几种 Connector 运行模式(优化)?
-
内存调优
十二、设计模式
=======
-
21种设计模式知识要点
-
请列举出在 JDK 中几个常用的设计模式?
-
什么是设计模式?你是否在你的代码里面使用过任何设计模式?
-
在 Java 中,什么叫观察者设计模式(observer design pattern)?
-
使用工厂模式最主要的好处是什么?在哪里使用?
-
在 Java 中,什么时候用重载,什么时候用重写?
-
在 Java 中,为什么不允许从静态方法中访问非静态变量?
-
设计一个 ATM 机,请说出你的设计思路?
-
举一个用 Java 实现的装饰模式(decorator design pattern)?它是作用于对象层次还是类层次
-
举例说明什么情况下会更倾向于使用抽象类而不是接口?
十三、算法&数据结构
==========
-
如何仅用递归函数和栈操作逆序一个栈?
-
将单向链表按某值划分成左边小、中间相等、右边大的形式
-
分别用递归和非递归方式实现二叉树先序、中序和后序遍历
-
斐波拉契系列问题的递归和动态规划
-
判断字符数组中是否有的字符都只出现过一次
-
在有序但含有空的数组中查找字符串
-
只用2GB内存在20亿个整数中找到出现次数最多的数
-
未排序数组中累加和小于或等于给定值的最长子数组长度
-
从5随机到7随机及其扩展
-
最大值减去最小值小于或等于num的子数组数量
-
环形单链表的约瑟夫问题
-
将单链表的每K个节点之间逆序
-
在二叉树中找到累加和为指定值的最长路径长度
-
判断一棵二叉树是否为搜索二叉树和完全二叉树
-
最长公共子序列问题
十四、并发
=====
-
什么是可重入性 , 为什么说Synchronized是可重入锁?
-
为什么说Synchronized是一个悲观锁?乐观锁的实现原理又是什么?什么是CAS,它有 什么特性?
-
乐观锁一定就是好的吗?
-
JVM对Java的原生锁做了哪些优化?
-
ReentrantLock 是如何实现可重入性的?
-
跟 Synchronized 相 比 ,可重入锁ReentrantLock其实现原理有什么不同?
-
如何让Java的线程彼此同步?你了解过哪些同步器?请分别介绍下 。
-
CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢?
-
线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?
-
既然提到可以通过配置不同参数创建出不同的线程池,那么Java中默认实现好的线程池又 有哪些呢?请比较它们的异同
-
请谈谈volatile有什么特点,为什么它能保证变量对所有线程的可见性?
-
什么是Java的内存模型,Java中各个线程是怎么彼此看到对方的变量的?
-
既然volatile能够保证线程间的变量可见性,是不是就意味着基于volatile变量的运算就是并 是安全的 ?
-
很多人都说要慎用ThreadLocal,谈谈你的理解,使用ThreadLocal需要注意些什么?
-
请谈谈AQS框架是怎么回事儿?
十五、操作系统/Linux
=============
-
死锁产生的原因
-
进程、线程区别,什么时候用线程
-
如何实现一个线程池,Java中线程池如何进行配置
-
linux中有哪些常见的指令,进行介绍
-
select、poll、epoll有没有了解过,讲解一下
-
线程切换,引申到Java阻塞➡️运行
-
如何分层复制/home目录到另一个目录?
-
什么是安装Linux所需的最小分区数量,以及如何查看系统启动信息?
-
如何暂停一个正在运行的进程,把其放在后台(不运行)?
-
什么是页面错误,它是怎么发生的?
最后
对于这些问题我都整理了答案,记录在这个Java学习笔记里,这份笔记包括了Spring,JVM,java基础,Java集合,Java并发编程,微服务,网络,Kafka,分布式,Redis,大厂面试解决方案,分布式事务,设计模式,算法,数据结构,MySQL等
完结
Redis基于内存,常用作于缓存的一种技术,并且Redis存储的方式是以key-value的形式。Redis是如今互联网技术架构中,使用最广泛的缓存,在工作中常常会使用到。Redis也是中高级后端工程师技术面试中,面试官最喜欢问的问题之一,因此作为Java开发者,Redis是我们必须要掌握的。
Redis 是 NoSQL 数据库领域的佼佼者,如果你需要了解 Redis 是如何实现高并发、海量数据存储的,那么这份腾讯专家手敲《Redis源码日志笔记》将会是你的最佳选择。
dis存储的方式是以key-value的形式。Redis是如今互联网技术架构中,使用最广泛的缓存,在工作中常常会使用到。Redis也是中高级后端工程师技术面试中,面试官最喜欢问的问题之一,因此作为Java开发者,Redis是我们必须要掌握的。
Redis 是 NoSQL 数据库领域的佼佼者,如果你需要了解 Redis 是如何实现高并发、海量数据存储的,那么这份腾讯专家手敲《Redis源码日志笔记》将会是你的最佳选择。
[外链图片转存中…(img-sS6VyyDs-1715626948349)]