java开发中间件学习记录(持续更新中~)

1 Redis

2JVM

3 java基础底层

4Mysql

5 spring

6 微服务

7.......(持续更新)

One:Redis篇

1:Redis

1.穿透 

1.1缓存穿透

1.1.1布隆过滤器 

1.2缓存击穿 

2:击穿 

1.3:缓存雪崩 

1.4:双写一致  

1.5.持久化(RDB,AOF)

 1.6删除策略

1.7淘汰策略 

1.8分布式锁 (setnx,redisson)

1.9Redis集群 

1.9.1主从复制 

1.9.2哨兵(Sentinel )

1.9.2.1脑裂 

1.9.3分片集群 

1.10 (为什么Redis这么快)I/O多路复用模型 

2:MYSQL

2.1如何定位慢查询 

2.2什么是索引 (了解索引吗)

2.3什么是聚集索引(聚簇索引)二级索引(非聚簇索引)

2.3.1回表查询 

2.4覆盖索引 

2.5MYSQL超大分页处理 

2.6索引创建的原则 

2.7索引失效 

2.7.1最左前缀法则 

 2.7.2范围查询右边列失效

2.7.3在索引列上进行运输操作 

2.7.4以%开头的模糊匹配

2.8sql优化 

2.9事务的特性 (ACID)

2.10并发事物带来的问题(脏读,不可重复读,幻读) 

2.11undo log,redo log 区别

2.12MVCC(多版本并发控制) 

2.13MYSQL主从同步原理 

2.14分库分表 

3: JVM:

3.1JVM组成部分 ,运行流程

3.2程序计数器 

3.3介绍一下Java堆

3.4虚拟机栈

3.4.1栈溢出 

3.5解释一下方法区

3.5.1常量池 

3.5.2运行时常量池 

3.6听说过直接内存吗:

3.7什么是类加载器,类加载器有哪些

3.8什么是双亲委派模型

3.9类加载的执行过程 

3.10对象什么时候被垃圾器回收

3.10.1可达性分析算法 

3.11垃圾回收算法有哪些

3.12JVM的分代回收

3.13有哪些垃圾回收器:

3.14 G1垃圾回收器

3.15强引用,软引用,弱引用,虚引用区别

3.16JVM调优的参数在哪里设置参数值

3.17JVM调优参数有哪些

3.18JVM调优工具

3.19java内存泄漏排查思路

3.20CPU飙高排查 

4:常见集合篇:

4.1List

4.1.1数字索引从0开始为什么

4.2ArrayList底层实现原理

4.3Arraylist扩容

4.4数字和list转换

4.5ArrayList和LinkedList的区别

4.6HashMap 

4.6.1红黑树 

4.6.2散列表 

4.7哈希冲突 

4.8HashMap的实现原理 

4.9HashMap的put方法具体流程

4.10HashMap的扩容机制

4.11hashMap的寻址公式

4.12hashmap多线程死循环

5:多线程:

5.1线程和进程的区别 

 5.2并行和并发的区别

5.3创建线程的方式

5.4runnable和callable(创建线程时) 的区别

5.5线程 run()和start()的区别

5.6线程包括那些状态(之间是如何转换的)

5.7多个线程之间的执行顺序

5.8 notify()和notifyAll()的区别

9:wait()和sleep()的区别

5.10如何停止一个运行的线程

2:

3:

5.11synchronized关键字的底层原理

5.12 锁升级

2:

5.13java内存模型

5.14CAS你知道吗

5.15volatile的理解 

简单说就是JVM为了对代码进行优化提高性能会在不影响结果的情况下把代码执行顺序改变,但多线程就可能会出现结果不对的问题

然后volatile原理就是加了一些屏障,使屏障后的代码一定不会比屏障前的代码先执行,从而实现有序性

5.16什么是AQS 

5.17ReentrantLock的实现原理 

5.18死锁产生的条件 

​​​​​​6:框架篇(spring( boot,mvc),mybatis)

7微服务:

8:消息中间件(MQ,Kafka)

9 设计模式

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入浅出Docker

1. Docker引擎 Docker引擎是用来运行和管理容器的核心软件。通常人们会简单的将其指代为Docker或Docker平台。 基于开放容器计划(OCI)相关的标准要求,Docker引擎采用了模块化的设计原则,其组件是可替换的。 Docker引擎由如下主…

k8s中的存储

目录 一 configmap 1.1 configmap的功能 1.2 configmap的使用场景 1.3 configmap创建方式 1.3.1 字面值创建 1.3.2 通过文件创建 1.3.3 通过目录创建 1.3.4 通过yaml文件创建 1.3.5 configmap的使用方式 1.3.5.1 使用configmap填充环境变量 1.3.5.2 通过数据卷使用c…

YOLOv10改进系列,YOLOv10颈部网络SPPF替换为FocalModulation

摘要 焦点调制网络(简称FocalNets),其中自注意力(SA)完全由焦点调制模块取代,用于在视觉中建模标记交互。焦点调制包括三个组件:(i)焦点情境化,通过一堆深度卷积层实现,从短到长范围编码视觉上下文,(ii)门控聚合,选择性地将上下文聚集到每个查询标记的调制器中…

词嵌入(二):基于上下文窗口的静态词嵌入(从NNLM、CW模型谈到基于层次Softmax、负采样的Word2Vec模型)

文章目录 一、经典神经语言模型(A Neural Probabilistic Language Model)二、C&W模型 (Collobert and Weston, 2008)2.1 文章背景2.2 模型架构(词向量的表示)2.2.1 Lookup-Table Layer(查找表)2.2.2 TD…

基于单片机的风机故障检测装置的设计与实现(论文+源码)

1 系统总体设计方案 通过对风机故障检测装置的设计与实现的需求、可行性进行分析,本设计风机故障检测装置的设计与实现的系统总体架构设计如图2-1所示,系统风机故障检测装置采用STM32F103单片机作为控制器,并通过DS18B20温度传感器、ACS712电…

VMware Fusion虚拟机Mac版 安装Win10系统教程

Mac分享吧 文章目录 Win10安装完成,软件打开效果一、VMware安装Windows10虚拟机1️⃣:准备镜像2️⃣:创建虚拟机3️⃣:虚拟机设置4️⃣:安装虚拟机(步骤和Win11安装步骤类似,此处相同步骤处没换…

dll修复工具4DDiG DLL Fixer,解决电脑dll丢失问题

4DDiG DLL Fixer是一款专业的DLL修复工具,旨在解决Windows系统中各种DLL相关问题。该工具能够快速全面地扫描计算机,检测并修复导致程序功能异常的DLL错误。它支持一键式操作,自动扫描、识别和替换缺失或损坏的DLL文件,从而帮助用…

opencv之Canny边缘检测

文章目录 前言1.应用高斯滤波去除图像噪声2.计算梯度3.非极大值抑制4.应用双阈值确定边缘5.Canny函数及使用 前言 Canny边缘检测是一种流行的边缘检测算法,用于检测图像中的边缘。它通过一系列步骤将图像中的像素边缘突出显示出来,主要分为以下几个步骤…

★ C++进阶篇 ★ 多态

Ciallo&#xff5e;(∠・ω< )⌒☆ ~ 今天&#xff0c;我将继续和大家一起学习C进阶篇第一章----多态 ~ ❄️❄️❄️❄️❄️❄️❄️❄️❄️❄️❄️❄️❄️❄️ 澄岚主页&#xff1a;椎名澄嵐-CSDN博客 C基础篇专栏&#xff1a;★ C基础篇 ★_椎名澄嵐的博客-CSDN博客 …

数据处理脚手架PyODPS入门体验

本文分享了初次使用PyODPS&#xff08;Python版的Open Data Processing Service&#xff09;的心路历程。作者通过实际案例&#xff0c;深入浅出地探讨了PyODPS相较于传统ODPS SQL在数据处理上的灵活性与便捷性&#xff0c;特别是在处理复杂JSON字段统计与多条件筛选方面展现出…

带你如何使用CICD持续集成与持续交付

目录 一、CICD是什么 1.1 持续集成&#xff08;Continuous Integration&#xff09; 1.2 持续部署&#xff08;Continuous Deployment&#xff09; 1.3 持续交付&#xff08;Continuous Delivery&#xff09; 二、git工具使用 2.1 git简介 2.2 git的工作流程 2.3 部署g…

基于R语言的统计分析基础:使用SQL语句操作数据集

在使用R语言数据分析时&#xff0c;可以融合SQL语言使数据聚集操作更加便利&#xff0c;同时也可以增加对SQL语句的熟悉。借助sqldf、DBI、RSDLite等包&#xff0c;可以在R环境中直接运用SQL语句&#xff0c;轻松实现数据的分组统计、汇总分析&#xff0c;SQL的强大查询能力简化…

腾讯云2024年数字生态大会开发者嘉年华(数据库动手实验)TDSQL-C初体验

在2024年9月5-6日&#xff0c;有幸参加了腾讯云举办的2024年数字生态大会开发者嘉年华。 有幸体验了腾讯的多项黑科技和云计算知识。特别是在“增一行代码”互动展区&#xff0c;体验了腾讯云云计算数据库TDSQL-C技术并进行了动手实验。这些技术充分展示了腾讯在云计算的强大实…

Vite + Electron 时,Electron 渲染空白,静态资源加载错误等问题解决

问题 如果在 electron 里直接引入 vite 打包后的东西&#xff0c;那么有些资源是请求不到的 这是我的引入方式 根据报错&#xff0c;我们来到 vite 打包后的路径看一看 &#xff0c;修改一下 dist 里的文件路径试了一试 修改后的样子&#xff0c;发现是可以的了 原因分析 …

粒子群算法(PSO算法)求解实例---旅行商问题 (TSP)

目录 一、采用PSO求解 (TSP)二、 旅行商问题2.1 实际例子&#xff1a;求解 6 个城市的 TSP2.2 **求解该问题的代码**2.3 代码运行过程截屏2.4 代码运行结果截屏&#xff08;后续和其他算法进行对比&#xff09; 三、 如何修改代码&#xff1f;3.1 减少城市坐标&#xff0c;如下…

Porcupine - 语音关键词唤醒引擎

文章目录 一、关于 Porcupine特点用例尝试一下 语言支持性能 二、Demo1、Python Demo2、iOS DemoBackgroundService DemoForegroundApp Demo 3、网页 Demo3.1 Vanilla JavaScript 和 HTML3.2 Vue Demos 三、SDK - Python 一、关于 Porcupine Porcupine 是一个高度准确和轻量级…

【软件测试】--xswitch将请求代理到测试桩

背景 在做软件测试的过程中&#xff0c;经常会遇见需要后端返回特定的响应数据&#xff0c;这个时候就需要用到测试桩&#xff0c;进行mock测试。 测试工程师在本地模拟后端返回数据时&#xff0c;需要将前端请求数据代理到本地&#xff0c;本文介绍xswitch插件代理请求到flas…

基于环境音频和振动数据的人类活动识别

这篇论文的标题是《Recognition of human activities based on ambient audio and vibration data》&#xff0c;作者是 Marcel Koch 等人&#xff0c;发表在 IEEE Access 期刊上。论文提出了一种基于环境音频和振动数据的分布式多传感器系统&#xff0c;用于识别人类活动。以下…

Anaconda安装并配置Python环境

背景概述 Anaconda&#xff0c;中文大蟒蛇&#xff0c;是一个开源的Anaconda是专注于数据分析的Python发行版本&#xff0c;包含了conda、Python等190多个科学包及其依赖项。 Anaconda就是可以便捷获取包且对包能够进行管理&#xff0c;包括了python和很多常见的软件库和一个…

web基础之RCE

简介&#xff1a;RCE称为远程代码执行漏洞&#xff1b;是互联网的一种安全漏洞&#xff1b;攻击者可以直接向后台服务器远程注入操作系统命令&#xff1b;从而操控后台系统&#xff1b;也是CTF比较常考的一个方面 1、eval执行 &#xff08;1&#xff09;分析后端代码&#xf…