当前位置: 首页 > news >正文

线程进阶-1 线程池

一.说一下线程池的执行原理

1.线程池的七大核心参数

(1)int corePoolSize:核心线程数。默认情况下核心线程会一直存活,当设置allowCoreThreadTimeout为true时,核心线程也会被超时回收。

(2)int maximumPoolSize:线程池能容纳的最大线程数。maximumPoolSize = 核心线程数 + 救急线程数。

(3)long keepAliveTime:线程闲置的超时时长。当线程闲置超时时,此线程会被回收,释放资源。超时回收默认情况下只针对救急线程。

(4)TimeUnit unit:keepAliveTime的时间单位,如TimeUnit.MILLISECONDS、TimeUnit.SECONDS等。

(5)BlockingQueue<Runnable> workQueue:任务队列。当核心线程数都被占用时,新提交的任务会被放到任务队列中等待。

(6)ThreadFactory threadFactory:线程工厂,为可选参数。

        a.ThreadFactory为一个接口,只提供一个newThread()方法,传入一个Runnable对象,返回一个执行该Runnable的Thread对象。用于定制线程对象的创建。

        b.若未指定ThreadFactory,则线程池会使用默认的ThreadFactory——只是创建Thread执行Runnable,不对线程作额外的处理。

(7)RejectedExecutionHandler handler:拒绝策略,为可选参数

        a.当核心线程、救急线程都被占用,且任务队列已满时,会对新提交的任务执行拒绝策略。

        b.若未指定拒绝策略,则线程池会默认使用AbortPolicy

2.线程池的拒绝策略

(1)AbortPolicy:丢弃新任务,并抛出异常。

(2)DiscardPolicy:丢弃新任务,但不会抛出异常。

(3)DiscardOldestPolicy:丢弃任务队列队头的任务,将新任务插入到任务队列队尾。

(4)CallerRunsPolicy:让调用者线程自己来执行任务。即如果当前线程A向线程池提交了一个任务,且该任务触发了线程池的CallerRunsPolicy拒绝策略,则线程池会将该任务退回给线程A,让线程A来执行该任务。

(5)自定义拒绝策略:实现RejectedExecutionHandler接口,并重写rejectedExecution()方法。

3.线程池的执行原理

对于新提交的任务:

(1)判断核心线程是否有空闲,若有空闲则交由核心线程执行。若核心线程都被占用,则继续判断

(2)判断等待队列是否有空位,若有空位则插入到队尾。若等待队列已满,则继续判断

(3)判断救急线程是否有空闲,若有空闲则交由救急线程执行。若救急线程都被占用,则执行拒绝策略

补充:

(1)核心线程和救急线程每执行完一个任务,都会再去等待队列中取待执行任务继续执行。若等待队列中没有任务,则默认情况下,核心线程进入空闲状态,救急线程开始闲置超时的计时。

(2)当核心线程都被占用且等待队列已满时,才会创建救急线程来执行新任务。被创建的救急线程,会直接忽视等待队列的任务,先去执行新提交的任务;等到新任务执行完,才会开始执行等待队列的任务。

二.线程池中常见的任务队列

1.ArrayBlockingQueue:基于数组结构的有界阻塞队列,任务执行顺序为FIFO

2.LinkedBlockingQueue:基于链表结构的有界阻塞队列,任务执行顺序为FIFO

3.DelayedWorkQueue:是一个优先级队列。在提交任务时可以指定当前任务需要延时多长时间后才执行,DelayedWorkQueue的任务执行顺序为当前队列中指定执行时间最早的任务。

4.SynchronousQueue:不存储元素的阻塞队列。每个线程的插入操作都需要等待另一个线程的移除操作,是线程和线程间的传递。

三.说一下ArrayBlockingQueue和LinkedBlockingQueue的区别

1.底层数据结构

(1)ArrayBlockingQueue底层是数组

(2)LinkedBlockingQueue底层是单向链表

2.容量

(1)ArrayBlockingQueue是强制有界,创建时需要传入一个int值作为容量

(2)LinkedBlockingQueue是默认无界,支持有界。默认容量为Integer.MAX_VALUE,创建时可以传入一个int值作为容量。

3.加锁方式

ArrayBlockingQueue和LinkedBlockingQueue都是使用ReentrantLock加锁。

(1)ArrayBlockingQueue的插入和删除操作都是只加一把锁,同时锁住入队和出队。

(2)LinkedBlockingQueue插入操作锁尾节点,不锁头节点;删除操作锁头节点,不锁尾节点。即在执行入队时可以出队,执行出队时可以入队,效率更高。

四.线程池的execute()和submit()方法的区别

线程池可以通过execute()或submit()方法来提交任务

1.执行对象不同

(1)execute(Runnable command):该方法用于执行Runnable接口的任务

(2)submit(Callable<T> task)、submit(Runnable task)、submit(Runnable task,T result):submit()的三个重载方法表明其既可以执行Callable接口任务也可以执行Runnable接口任务。传入的Runnable接口在内部会先被转化为Callable接口再作为任务执行,因此submit()方法最终的执行对象都是Callable接口。

2.返回值不同

(1)execute()方法执行对象是Runnable接口任务,Runnable的run()方法没有返回值,因此execute()方法也没有返回值。execute()主要用于执行不需要返回结果的任务。

(2)submit()方法最终执行对象都是Callable接口任务,其返回值为Future<T>,可以调用Future的get()方法获取任务执行后的返回值。

3.异常处理不同

(1)execute()提交的任务在执行中遇到异常时,会将异常传递给线程的UncaughtExceptionHandler处理,默认是直接将异常抛出。

(2)submit()提交的任务在执行中遇到异常时,仅仅是停止执行任务,但不会将异常立即抛出,相当于暂时吞掉异常;直到外部调用Future的get()方法尝试获取任务执行的返回值时,才会将异常抛出。即允许延迟处理异常。

五.线程池有哪几种状态?

1.RUNNING:线程池的初态,代表线程池正在处理和接收任务。

2.SHUTDOWN:调用shutdown()方法会进入此状态。表明线程池不再接收新任务,但会继续处理已经提交到等待队列的任务。

3.STOP:调用shutdownNow()方法会进入此状态。表明线程池不再接收新任务,也不会再处理等待队列中的任务,同时还会尝试中断正在执行的任务。

4.TIDYING:过渡态,当线程池的所有任务都已经终止(无论是正常执行完还是通过取消或异常终止),并且所有工作线程都关闭,就会进入此状态。该状态下,线程池会执行terminated()钩子方法。

5.TERMINATED:最终态。当terminated()方法执行完就会进入此状态,代表线程池完全终止。

六.线程池的种类有哪些?

Executors类提供了创建多种线程池的静态方法,常见的有4种:

1.newFixedThreadPool:固定线程数的线程池。

(1)核心线程数=最大线程数,无救急线程。

(2)任务队列为LinkedBlockingQueue,容量为默认的Integer.MAX_VALUE。

(3)适用于任务量已知,相对耗时的任务。

2.newSingleThreadPool:单线程化的线程池。

(1)核心线程数=最大线程数=1,作为唯一的工作线程;无救急线程。

(2)任务队列为LinkedBlockingQueue,容量为默认的Integer.MAX_VALUE。

(3)适用于按照顺序执行的任务。

3.newCachedThreadPool:可缓存线程

(1)核心线程数=0,最大线程数=救急线程数=Integer.MAX_VALUE,即全为救急线程在工作,因此可以灵活创建、回收线程。

(2)任务队列为SynchronousQueue

(3)适用于任务数比较密集,但每个任务执行时间较短的情况。

4.newScheduledThreadPoolExecutor:具有延迟和周期执行功能的线程池。

(1)核心线程数自定义,最大线程数=Integer.MAX_VALUE。

(2)任务队列为DelayedWorkQueue,使用schedule()提交任务,指定任务的延时执行时间。

七.为什么不建议使用Executors类提供的方法创建线程?

1.FixedThreadPool和SignalThreadPool都允许任务队列的长度为Integer.MAX_VALUE,可能会堆积大量的任务请求,导致OOM。

2.newCachedThreadPool和newScheduledThreadPool的最大线程数都为Integer.MAX_VALUE,可能会创建大量的线程,导致OOM。

八.如何控制某个方法允许并发访问线程的数量?

1.使用newFixedThreadPool,但有OOM的风险。

2.使用Semaphore类,每一个线程访问该方法都acquire()获取一个信号量,若信号量数大于0,则该线程获取到一个信号量,信号量数减1;若信号量数小于0,则该线程阻塞;若线程执行完该方法,则release()释放一个信号量,信号量数加1。

九.如何确定线程池的核心线程数?

假设cpu的核数为N

1.对于高并发、执行时间短的任务:需要减少线程数以减少线程上下文切换带来的消耗。因此核心线程数设置为N+1。

2.对于并发不高、任务执行时间长的任务:

(1)IO密集型任务:例如文件读写、DB读写、网络请求等,不需要占用过多cpu。核心线程数设置为2N+1。

(2)cpu密集型任务:例如计算型代码、Bitmap转换、Gson转换等,需大量占用cpu,需要减少线程数以减少线程上下文切换带来的消耗。因此核心线程数设置为N+1。

十.说一下线程池的使用场景

1.数据批量导出

(1)使用线程池+CountDownLatch批量将数据库中的数据导出,避免OOM。

(2)场景:例如使用分页查询去导出数据库中的数据,线程池的每个线程负责一页数据的导出,并发执行,每有一个线程执行完,CountDownLatch减一,直到所有线程执行完,CountDownLatch等于零,主线程才继续执行。

2.数据汇总

(1)如果一个请求要调用多个接口来汇总数据,且接口间没有依赖关系,则可以使用线程池+Future获取调用结果的方式来并发执行,提升性能。

3.异步线程

(1)为了避免下一级方法影响上一级方法响应时间,可以使用异步线程并发调用下一级方法(前提是不需要下一级方法的返回值),提高响应速率。

相关文章:

线程进阶-1 线程池

一.说一下线程池的执行原理 1.线程池的七大核心参数 &#xff08;1&#xff09;int corePoolSize&#xff1a;核心线程数。默认情况下核心线程会一直存活&#xff0c;当设置allowCoreThreadTimeout为true时&#xff0c;核心线程也会被超时回收。 &#xff08;2&#xff09;i…...

LabVIEW中PID控制器系统的噪声与扰动抑制策略

在LabVIEW中处理PID控制器系统中的噪声和外部扰动&#xff0c;需要从信号处理、控制算法优化、硬件滤波和系统设计四个角度入手。采用滤波技术、调节PID参数、增加前馈控制和实施硬件滤波器等方法&#xff0c;可以有效减少噪声和扰动对系统性能的影响&#xff0c;提高控制系统的…...

JavaWeb笔记整理+图解——Listener监听器

欢迎大家来到这一篇章——Listener监听器 监听器和过滤器都是JavaWeb服务器三大组件&#xff08;Servlet、监听器、过滤器&#xff09;之一&#xff0c;他们对于Web开发起到了不可缺少的作用。 ps&#xff1a;想要补充Java知识的同学们可以移步我已经完结的JavaSE笔记&#x…...

AIGC智能办公实战 课程,祝你事业新高度

在数字化时代&#xff0c;人工智能&#xff08;AI&#xff09;已经渗透到我们生活的方方面面&#xff0c;从智能家居到自动驾驶&#xff0c;从医疗诊断到金融分析&#xff0c;AI助手正在改变我们的工作方式和生活质量。那么&#xff0c;你是否想过自己也能从零开始&#xff0c;…...

专科生听劝 这种情况你就不要专转本了

罗翔老师说过&#xff0c;读书学习主要作用是提高人的下限 我们能掌握的只有学习&#xff0c;以确保学历不会太差再去等机遇让自己活得更好 大部分情况来说&#xff0c;专科生努力去专转本挺好的提升自己准没错&#xff0c;我当年也是一心这样想的&#xff0c;但今天不得不说点…...

MySQL增删查改初阶

目录 一&#xff0c;数据库操作 1.关键字 show 显示当前数据库有哪些&#xff1a;show databases&#xff1b; 2.创建数据库 3.选中数据库 4.删除数据库 二&#xff0c;表的操作&#xff0c;在选中数据库的基础之上 1.查看表的结构 2.创建表 3.查看当前选中的数据库中…...

IService 接口中定义的常用方法

文心一言生成 以下是一些 IService 接口中定义的常用方法&#xff08;以你提供的 UserSQL 类为例&#xff0c;该类继承自 ServiceImpl&#xff0c;因此也会拥有这些方法&#xff09;&#xff1a; 插入&#xff08;新增&#xff09; boolean save(T entity): 插入一条记录&…...

api网关kong对高频的慢接口进行熔断

一、背景 在生产环境&#xff0c;后端服务的接口响应非常慢&#xff0c;是因为数据库未创建索引导致。 如果QPS低的时候&#xff0c;因为后端服务有6个高配置的节点&#xff0c;虽然接口慢&#xff0c;还未影响到服务的正常运行。 但是&#xff0c;当QPS很高的时候&#xff0c…...

python作业:实现一个任务列表管理系统,使用到python类、对象、循环等知识

实现一个简单的任务列表管理系统&#xff0c;可以用于python学习的作业或者练习。系统的功能包括&#xff1a; 用户可以添加任务、查看任务列表、标记任务为已完成&#xff0c;以及删除任务。 代码如下&#xff1a; class Task: def __init__(self, name, completedFalse):…...

大宋咨询(深圳产品价格调查)如何开展电子商品渠道价格监测

开展电子商品渠道价格监测是当今电商时代的重要任务之一。随着电子商务的迅猛发展&#xff0c;电子商品的价格波动日益频繁&#xff0c;市场竞争也愈发激烈。为了解优化渠道管理策略&#xff0c;提升品牌竞争力&#xff0c;大宋咨询&#xff08;深圳市场调查&#xff09;受客户…...

py黑帽子学习笔记_web攻击

python网络库 py2的urllib2 py3好像把urllib2继承到了标准库urllib&#xff0c;直接用urllib就行&#xff0c;urllib2在urllib里都有对应的接口 py3的urllib get请求 post请求&#xff0c;和get不同的是&#xff0c;先把post请求数据和请求封装到request对象&#xff0c;再…...

MVC、MVP 和 MVVM 架构总结

MVC、MVP 和 MVVM 是常见的软件架构模式&#xff0c;主要用于组织应用程序的结构&#xff0c;特别是在用户界面和业务逻辑之间进行分离。以下是对它们的详细解释&#xff0c;包括它们的差异、优缺点。 MVC&#xff08;Model-View-Controller&#xff09; 结构 Model&#xf…...

C++ vector的使用和简单模拟实现(超级详细!!!)

目录 前言 1.STL是什么 2.vector使用 2.1 vector简介 2.2 常用接口函数 1. 构造函数 2.operator[ ]和size&#xff0c;push_back 3. 用迭代器进行访问和修改 4. 范围for遍历 5.修改类型函数 pop_back find insert erase 6. 容量相关函数capacity resize reserve 3.…...

MySQL中,不能在一个DML(数据操纵语言,如INSERT, UPDATE, DELETE)语句中直接引用目标表进行子查询

错误示例 <delete id"deleteOldRelations">DELETE FROM departments_closure_tableWHERE descendant IN ( SELECT descendant FROM departments_closure_tableWHERE ancestor #{departmentId})</delete>程序运行之后&#xff0c;会报错&#xff1a;You …...

【CH32V305FBP6】4. systick 配置

配置 main.c void SYSTICK_Init_Config(u_int64_t ticks) {SysTick->SR & ~(1 << 0);//clear State flagSysTick->CMP ticks - 1;SysTick->CNT 0;SysTick->CTLR 0xF;NVIC_SetPriority(SysTicK_IRQn, 15);NVIC_EnableIRQ(SysTicK_IRQn); }中断计数 …...

【PECL】在扩展中实现 autoload

【PECL】在扩展中实现 autoload 摘要PHP代码想这么写C 代码这么实现 摘要 php-8.3.x 用扩展写个框架。想实现类管理器&#xff0c;自动加载&#xff0c;上代码&#xff1a; PHP代码想这么写 $ws new \Ziima\Applet(); $ws->import(Ziima, ../base/core); $ws->runAu…...

企业微信H5授权登录

在企业中如果需要在打开的网页里面携带用户的身份信息&#xff0c;第一步需要获取code参数 如何实现企业微信H5获取当前用户信息即accessToken&#xff1f; 1.在应用管理--》创建应用 2.创建好应用&#xff0c;点击应用主页-》设置-》网页-》将授权链接填上去 官方文档可以看…...

玩机进阶教程------修改gpt.bin分区表地址段 完全屏蔽系统更新 fast刷写分区表 操作步骤解析【二】

上期博文简单说明了分区表的基本常识。我们在有些环境中需要屏蔽手机的系统更新选项。除了以前博文中说明的修改系统更新下载文件夹的方法。还可以通过修改分区表类达到目的。在一些辅助维修工具上面带修改分区表功能。修改后效果为屏蔽系统更新和可以恢复出厂。原则上不深刷都…...

Java实现数据结构---数组

文章目录 概念存储原理数组的操作完整代码 概念 数组是&#xff08;Array&#xff09;是有限个相同类型的变量所组成的有序集合&#xff0c;数组中的每一个变量为称为元素。数组是最简单、最常用的数据结构。 数组下标从零开始。 存储原理 数组用一组连续的内存空间来存储一…...

java解析excel文件,返回json

我这里用的是springboot项目&#xff0c;配合Maven使用的。首先需要引入依赖&#xff1a; <dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>4.1.2</version></dependency><dependency…...

uniapp 添加字体ttf

效果图如下 一、逻辑概述 在uniapp中使用字体&#xff0c;一共分成两种情况&#xff0c;一种是普通vue页面&#xff0c;一种是nvue页面引入字体。。 1.vue页面引入字体需要如下步骤 1. 先选择下载一种字体&#xff1a;字体格式一般为 ttf后缀名 黄凯桦律师手写体免费下载和在线…...

Linux入门攻坚——24、BIND编译安装、Telnet和OpenSSH

BIND编译安装 对于没有rpm包&#xff0c;需要源代码编译安装。 1、下载源代码&#xff1a;bind-9.12.2-P1.tar.gz&#xff0c;解压&#xff1a;tar -xf bind-9.12.2-P1.tar.gz 2、完善环境&#xff1a; 1&#xff09;增加用户组named&#xff1a;groupadd -g 53 named 2&…...

1.5.3 基于Java配置方式使用Spring MVC

本实战教程主要介绍了如何使用Java配置方式来使用Spring MVC框架。相较于XML配置方式&#xff0c;Java配置方式提供了一种更为简洁和灵活的配置方法。 项目创建与配置 创建一个Jakarta EE项目&#xff0c;并设置项目名称和位置。选择Jakarta EE 10版本&#xff0c;不添加依赖&a…...

Artifactory清理二进制文件丢失的制品

一、摘要 当制品上传到 Artifactory 时&#xff0c;Artifactory 会在数据库中记录制品的相关元数据信息&#xff0c;包括文件路径、大小、校验和&#xff08;如 MD5、SHA1&#xff09;、上传时间、索引、依赖等。实际的制品二进制文件会存储在指定的存储后端&#xff0c;具体的…...

C#中的数组探索

在C#编程语言中&#xff0c;数组是一种基本的数据结构&#xff0c;用于存储固定大小的同类型元素序列。本文将深入探讨C#数组的各个方面&#xff0c;包括定义、赋值、范围操作、切片、多维数组&#xff08;矩形与锯齿形&#xff09;、简化初始化表达式以及边界检查。 数组定义…...

身份认证与口令攻击

身份认证与口令攻击 身份认证身份认证的五种方式口令认证静态口令动态口令(一次性口令)动态口令分类 密码学认证一次性口令认证S/KEY协议改进的S/KEY协议 其于共享密钥的认证 口令行为规律和口令猜测口令规律口令猜测 口令破解操作系统口令破解Windows密码存储机制Windows密码破…...

卷积网络迁移学习:实现思想与TensorFlow实践

摘要&#xff1a;迁移学习是一种利用已有知识来改善新任务学习性能的方法。 在深度学习中&#xff0c;迁移学习通过迁移卷积网络&#xff08;CNN&#xff09;的预训练权重&#xff0c;实现了在新领域或任务上的高效学习。 下面我将详细介绍迁移学习的概念、实现思想&#xff0c…...

Ansible04-Ansible Vars变量详解

目录 写在前面6 Ansible Vars 变量6.1 playbook中的变量6.1.1 playbook中定义变量的格式6.1.2 举例6.1.3 小tip 6.2 共有变量6.2.1 变量文件6.2.1.1 变量文件编写6.2.1.2 playbook编写6.2.1.3 运行测试 6.2.2 根据主机组使用变量6.2.2.1 groups_vars编写6.2.2.2 playbook编写6.…...

Flutter 中的 SliverCrossAxisGroup 小部件:全面指南

Flutter 中的 SliverCrossAxisGroup 小部件&#xff1a;全面指南 Flutter 是一个功能丰富的 UI 开发框架&#xff0c;它允许开发者使用 Dart 语言来构建高性能、美观的移动、Web 和桌面应用。在 Flutter 的丰富组件库中&#xff0c;SliverCrossAxisGroup 是一个较少被使用的组…...

开源还是闭源这是一个问题

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…...

数据结构与算法笔记:基础篇 - 栈:如何实现浏览器的前进和后退功能?

概述 浏览器的前进、后退功能&#xff0c;你肯定很熟悉吧&#xff1f; 当依次访问完一串页面 a-b-c 之后&#xff0c;点击浏览器的后退按钮&#xff0c;就可以查看之前浏览过的页面 b 和 a。当后退到页面 a&#xff0c;点击前进按钮&#xff0c;就可以重新查看页面 b 和 c。但…...

【AIGC】大型语言模型在人工智能规划领域模型生成中的探索

大型语言模型在人工智能规划领域模型生成中的新应用 一、引言二、LLM在规划领域模型生成中的潜力三、实证分析&#xff1a;LLM在规划领域模型生成中的表现四、代码实例&#xff1a;LLM在规划领域模型生成中的应用五、结论与展望 一、引言 随着人工智能技术的迅猛发展&#xff0…...

从零开始学习Slam-旋转矩阵旋转向量四元组(二)

本文参考&#xff1a;计算机视觉life 仅作笔记用 书接上回&#xff0c;上回不清不楚的介绍了旋转矩阵&旋转向量和四元组 现在回顾一下重点&#xff1a; 本着绕谁谁不变的变则 假设绕z轴旋转θ&#xff0c;旋转矩阵为&#xff1a; 再回顾一下旋转向量的表示以及这个基本记不…...

基于Spring Security添加流控

基于Spring Security添加流控的过程&#xff1a; 步骤1: 添加依赖 确保项目中包含了Spring Security和Sentinel-Core的相关依赖。在Maven项目中&#xff0c;可以在pom.xml中添加如下依赖&#xff1a; <!-- Spring Security --> <dependency><groupId>org.…...

Python | Leetcode Python题解之第119题杨辉三角II

题目&#xff1a; 题解&#xff1a; class Solution:def getRow(self, rowIndex: int) -> List[int]:row [1, 1]if rowIndex < 1:return row[:rowIndex 1]elif rowIndex > 2:for i in range(rowIndex - 1):row [row[j] row[j 1] for j in range(i 1)]row.inser…...

物联网应用系统与网关

一. 传感器底板相关设计 1. 传感器设计 立创EDA传感器设计举例。 2. 传感器实物图 3. 传感器测试举例 测试激光测距传感器 二. 网关相关设计 1. LORA&#xff0c;NBIOT等设计 2. LORA&#xff0c;NBIOT等实物图 3. ZigBee测试 ZigBee测试 4. NBIoT测试 NBIoT自制模块的测试…...

系统稳定性概览

系统稳定性 系统稳定性&#xff0c;包括&#xff1a;监控、 告警、性能优化、慢sql、耗时接口等。 系统的稳定性的治理&#xff0c;可以围绕这几方面展开。 监控 Prometheus 监控并收集数据。监控 qps&#xff0c;tps&#xff0c; rt , cpu使用率&#xff0c;cpu load&#…...

Redis-Cluster模式基操篇

一、场景 1、搞一套6个主节点的Cluster集群 2、模拟数据正常读写 3、模拟单点故障 4、在不停服务的情况下将集群架构改为3主3从 二、环境规划 6台独立的服务器&#xff0c;端口18001~18006 192.169.14.121 192.169.14.122 192.169.14.123 192.169.14.124 192.169.14.125 192…...

Golang | Leetcode Golang题解之第113题路径总和II

题目&#xff1a; 题解&#xff1a; type pair struct {node *TreeNodeleft int }func pathSum(root *TreeNode, targetSum int) (ans [][]int) {if root nil {return}parent : map[*TreeNode]*TreeNode{}getPath : func(node *TreeNode) (path []int) {for ; node ! nil; no…...

云计算与 openstack

文章目录 一、 虚拟化二、云计算2.1 IT系统架构的发展2.2 云计算2.3 云计算的服务类型 三、Openstack3.1 OpenStack核心组件 一、 虚拟化 虚拟化使得在一台物理的服务器上可以跑多台虚拟机&#xff0c;虚拟机共享物理机的 CPU、内存、IO 硬件资源&#xff0c;但逻辑上虚拟机之…...

golang语言的gofly快速开发框架如何设置多样的主题说明

本节教大家如何用gofly快速开发框架后台内置设置参数&#xff0c;配置出合适项目的布局及样式、主题色&#xff0c;让你您的项目在交互上加分&#xff0c;也是能帮你在交付项目时更容易得到客户认可&#xff0c;你的软件使用客户他们一般都是不都技术的&#xff0c;所以当他们拿…...

lynis安全漏洞扫描工具

Lynis是一款Unix系统的安全审计以及加固工具&#xff0c;能够进行深层次的安全扫描&#xff0c;其目的是检测潜在的时间并对未来的系统加固提供建议。这款软件会扫描一般系统信息&#xff0c;脆弱软件包以及潜在的错误配置。 安装 方式1 git下载使用git clone https://github…...

C++ 多重继承的内存布局和指针偏移

在 C 程序里&#xff0c;在有多重继承的类里面。指向派生类对象的基类指针&#xff0c;其实是指向了派生类对象里面&#xff0c;该基类对象的起始位置&#xff0c;该位置相对于派生类对象可能有偏移。偏移的大小&#xff0c;等于派生类的继承顺序表里面&#xff0c;排在该类前面…...

centos时间不对

检查当前时区是否正确 timedatectl status如果时区不正确&#xff0c;使用以下命令设置正确的时区&#xff08;将Asia/Shanghai替换为您所在的时区&#xff09;&#xff1a; timedatectl set-timezone Asia/Shanghai如果时区正确但时间不准确&#xff0c;使用以下命令同步网络…...

通过Redis实现防止接口重复提交功能

本功能是在切面执行链基础上实现的功能&#xff0c;如果不知道切面执行链的同学&#xff0c;请看一下我之前专门介绍切面执行链的文章。 在SpringBoot项目中实现切面执行链功能-CSDN博客 1.定义防重复提交handler /*** 重复提交handler**/ AspectHandlerOrder public class …...

如何构建最小堆?

方式1&#xff1a;上浮调整 /*** 上浮调整(小的上浮)*/ public static void smallUp1(int[] arr, int child) {int parent (child - 1) / 2;while (0 < child && arr[child] < arr[parent]) { // 0 < child说明这个节点还是叶子arr[child] arr[child] ^ ar…...

基于Netty实现安全认证的WebSocket(wss)客户端

1.Netty服务端 服务端代码参考【基于Netty实现安全认证的WebSocket&#xff08;wss&#xff09;服务端-CSDN博客】 2.Netty客户端 客户端代码参考【基于Netty实现WebSocket客户端-CSDN博客】中两种都可以&#xff1b;这里用的是第一种。 新增SslHandler的代码&#xff1a; …...

代码随想录算法训练营第四十四天 | 01背包问题 二维、 01背包问题 一维、416. 分割等和子集

01背包问题 二维 代码随想录 视频讲解&#xff1a;带你学透0-1背包问题&#xff01;| 关于背包问题&#xff0c;你不清楚的地方&#xff0c;这里都讲了&#xff01;| 动态规划经典问题 | 数据结构与算法_哔哩哔哩_bilibili 1.dp数组定义 dp[i][j] 下标为[0,i]之间的物品&…...

redis常见使用场景

文章目录 redis常见使用场景全局ID位统计购物车用户消息时间线timeline抽奖商品筛选分布式锁限流redis实现计数器排行榜消息队列redis 如何实现延时队列 redis生产常用的场景 redis常见使用场景 Redis 是一种高性能的内存数据库&#xff0c;广泛应用于各种场景中。以下是 Redi…...

模糊C均值(FCM)算法更新公式推导

模糊C均值&#xff08;FCM&#xff09;算法更新公式推导 目标函数 FCM的目标函数为&#xff1a; J m ∑ i 1 n ∑ j 1 k u i j m ∥ x i − c j ∥ 2 J_m \sum_{i1}^n \sum_{j1}^k u_{ij}^m \|x_i - c_j\|^2 Jm​i1∑n​j1∑k​uijm​∥xi​−cj​∥2 其中&#xff1a; …...