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

分布式、高并发-Day03

以下是 Day 3 详细学习内容(线程池拒绝策略实战:DiscardOldestPolicy与CallerRunsPolicy,30 分钟完整计划),包含策略原理、分步代码实战和场景解析:

📖 今日学习目标

  1. 掌握DiscardOldestPolicy(丢弃最老任务)与CallerRunsPolicy(调用者执行)的核心逻辑
  2. 理解两种策略的适用场景(如日志系统 vs 用户请求系统)
  3. 实战:通过代码对比两种策略的不同行为

⏰ 时间分配

时间段任务详细内容
0-10 分钟理论:拒绝策略深度解析1. DiscardOldestPolicy原理:为何丢弃队列头部任务?2. CallerRunsPolicy优势:减缓任务提交速度3. 生产场景选择建议
10-25 分钟实战:双策略对比实验1. 编写DiscardOldestPolicy示例2. 编写CallerRunsPolicy示例3. 观察任务执行顺序与线程归属
25-30 分钟总结与扩展1. 记录两种策略的核心区别2. 思考:如何避免DiscardOldestPolicy导致关键任务丢失?3. 扩展:如何监控拒绝策略的触发次数?

🔍 理论详解:两种核心拒绝策略

  1. DiscardOldestPolicy(丢弃最老任务)
  • 核心逻辑:
    当任务无法处理时,丢弃队列中等待时间最长的任务(队列头部任务),然后尝试将新任务加入队列。
// 源码关键逻辑(简化版)
public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {if (!e.isShutdown()) {e.getQueue().poll(); // 丢弃队列头部任务e.execute(r); // 尝试执行新任务}
}
  • 适用场景:
    • 实时性要求高的场景(如用户最新操作),允许牺牲旧任务(如股票行情更新)
    • 日志系统:优先处理最新日志,旧日志可能已过时
  1. CallerRunsPolicy(调用者执行)
  • 核心逻辑:
    当任务无法处理时,由提交任务的线程(通常是主线程)直接执行任务,而不是由线程池中的工作线程执行。
// 源码关键逻辑(简化版)
public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {if (!e.isShutdown()) {r.run(); // 调用者线程直接执行任务}
}
  • 优势:
    • 减缓任务提交速度:主线程执行任务时,后续提交会被阻塞,避免线程池被压垮
    • 保护线程池:防止短时间内大量任务涌入导致系统崩溃

💻 实战步骤:双策略对比实验

  • 实验 1:DiscardOldestPolicy(丢弃最老任务)
import java.util.concurrent.*;public class DiscardOldestDemo {public static void main(String[] args) {// 线程池配置:核心1,最大2,队列容量2,拒绝策略丢弃最老任务ExecutorService pool = new ThreadPoolExecutor(1,                  // 核心线程12,                  // 最大线程260,TimeUnit.SECONDS,new ArrayBlockingQueue<>(2),  // 队列容量2new ThreadPoolExecutor.DiscardOldestPolicy());// 提交4个任务(编号0-3,模拟时间顺序)for (int i = 0; i < 4; i++) {int taskId = i;pool.execute(() -> {System.out.println("执行任务:" + taskId + ",线程:" + Thread.currentThread().getName());});try {Thread.sleep(100);  // 控制提交间隔,确保任务按顺序进入队列} catch (InterruptedException e) {e.printStackTrace();}}pool.shutdown();}
}
  • 执行流程:
  1. 任务 0 由核心线程执行
  2. 任务 1、2 进入队列(队列满)
  3. 任务 3 提交时,队列满且线程数未达最大,触发策略:丢弃队列头部任务 0,任务 3 入队
  • 预期输出:
执行任务:0,线程:pool-1-thread-1  
执行任务:1,线程:pool-1-thread-1(核心线程处理完0后处理1)  
执行任务:3,线程:pool-1-thread-1(任务2被丢弃,任务3入队)  
  • 实验 2:CallerRunsPolicy(调用者执行)
public class CallerRunsDemo {public static void main(String[] args) {// 线程池配置:核心1,队列容量1,拒绝策略由调用者执行ExecutorService pool = new ThreadPoolExecutor(1,1,  // 最大线程=核心线程(无非核心线程)0,TimeUnit.SECONDS,new ArrayBlockingQueue<>(1),  // 队列容量1new ThreadPoolExecutor.CallerRunsPolicy());// 提交3个任务,第3个任务由主线程执行for (int i = 0; i < 3; i++) {int taskId = i;pool.execute(() -> {try {Thread.sleep(500);  // 模拟处理耗时System.out.println("任务" + taskId + "执行,线程:" + Thread.currentThread().getName());} catch (InterruptedException e) {e.printStackTrace();}});}pool.shutdown();}
}
  • 关键现象:
    • 任务 0 由核心线程执行
    • 任务 1 进入队列
    • 任务 2 提交时,队列满且无线程扩展空间,触发策略:由主线程(main线程)执行任务 2
  • 预期输出:
任务0执行,线程:pool-1-thread-1  
任务1执行,线程:pool-1-thread-1(500ms后)  
任务2执行,线程:main(主线程直接执行)  

📝 今日总结与扩展

  1. 核心策略对比表
策略丢弃任务?执行线程适用场景风险点
DiscardOldest是(最老)线程池线程优先处理新任务(如实时数据)可能丢失重要的早期任务
CallerRuns调用者线程保护线程池(如用户请求入口)主线程被阻塞,影响后续提交
  1. 扩展思考(5 分钟)
  • 问题 1:如何统计拒绝策略的触发次数?
    答案:自定义拒绝策略,继承RejectedExecutionHandler,重写rejectedExecution方法并添加计数器:
class CustomHandler implements RejectedExecutionHandler {private AtomicInteger rejectCount = new AtomicInteger(0);@Overridepublic void rejectedExecution(Runnable r, ThreadPoolExecutor e) {rejectCount.incrementAndGet();// 原策略逻辑...}
}
  • 问题 2:生产环境如何选择拒绝策略?
    提示:
    核心业务(如订单支付):用AbortPolicy,通过 try-catch 捕获异常并记录
    非核心业务(如日志、监控):用DiscardPolicy或DiscardOldestPolicy
    入口层服务(如 API 网关):用CallerRunsPolicy,避免客户端请求被直接拒绝

🔧 工具与环境准备

  • 代码要求:直接复制两个 Java 文件,分别运行观察输出
  • 调试技巧:
    在pool.execute()后添加System.out.println(“任务” + taskId + “提交”);,观察提交顺序
    使用pool.getRejectedExecutionHandler()验证当前策略类型
    ✅ 今日任务 checklist
    ✅ 理解两种拒绝策略的核心逻辑
    ✅ 成功运行两个实验,观察到任务丢弃与调用者执行的差异
    ✅ 记录 1 个生产场景应用案例(如:用户注册接口用CallerRunsPolicy防止突发流量压垮线程池)

相关文章:

分布式、高并发-Day03

以下是 Day 3 详细学习内容&#xff08;线程池拒绝策略实战&#xff1a;DiscardOldestPolicy与CallerRunsPolicy&#xff0c;30 分钟完整计划&#xff09;&#xff0c;包含策略原理、分步代码实战和场景解析&#xff1a; &#x1f4d6; 今日学习目标 掌握DiscardOldestPolicy…...

高等数学第四章---不定积分(4.4有理函数的不定积分2)

&4.4有理函数的不定积分2 篇幅有限制&#xff0c;例题的解答会占大量字符&#xff0c;html限制字符为22000个左右。这里继续探讨上文的有理函数的不定积分。 一、三角函数有理式的不定积分 由 sin ⁡ x \sin x sinx, cos ⁡ x \cos x cosx 以及常数经过有限次加、减、…...

C++中指针使用详解(4)指针的高级应用汇总

C 中指针的高级应用非常丰富&#xff0c;掌握这些内容能让你写出更高性能、更底层控制力强的代码。下面是应用模块梳理和例子讲解。 目录预览 函数指针与回调机制指针数组 vs 数组指针指针与类成员函数&#xff08;成员函数指针&#xff09;智能指针&#xff08;unique_ptr, s…...

Java 8 非对称加密代码示例

以下是使用Java 8实现RSA非对称加密的完整代码示例&#xff0c;包括密钥生成、加密和解密过程。 1. 生成RSA密钥对 import java.security.*; import java.security.spec.PKCS8EncodedKeySpec; import java.security.spec.X509EncodedKeySpec; import java.util.Base64; impor…...

Linux环境基础与开发工具使用

1. Linux编译器vim 1.1 vim的基本概念讲解 vim有很多种模式&#xff0c;我们初学者常用的就是命令模式&#xff08;command mode&#xff09;、插入模式&#xff08;Insert mode&#xff09;和底行模式&#xff08;last line mode&#xff09;。 命令/正常模式(Normal mode) …...

【BUG】‘DetDataSample‘ object has no attribute ‘_gt_sem_seg‘

问题&#xff1a; 使用mmdetection框架使用COCO格式训练自定义数据集时&#xff0c;其中模型使用HTC模型时出现如下问题&#xff1a; AttributeError: ‘DetDataSample’ object has no attribute ‘_gt_sem_seg’. Did you mean: ‘gt_sem_seg’? results self(**data, mode…...

C# Winforms 本地化 多语言支持 字符串资源

初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github&#xff1a;codetoys&#xff0c;所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C的&#xff0c;可以在任何平台上使用。 源码指引&#xff1a;github源…...

ts bug 找不到模块或相应类型的声明,@符有红色波浪线

解决方法&#xff1a;在env.d.ts文件中添加以下代码&#xff0c;这段代码是一个 TypeScript 的声明文件&#xff0c;用于让 TypeScript 知道如何处理 Vue 单文件组件&#xff08;.vue 文件&#xff09;的导入。 /// <reference types"vite/client" /> // 声明…...

赛灵思 XCZU11EG-2FFVC1760I XilinxFPGAZynq UltraScale+ MPSoC EG

XCZU11EG-2FFVC1760I 是 Zynq UltraScale MPSoC EG 系列中性能最强的器件之一&#xff0c;集成了四核 ARM Cortex-A53 应用处理器、双核 Cortex-R5 实时处理器与 Mali-400 MP2 GPU&#xff0c;并结合了 653,100 个逻辑单元与丰富的片上存储资源&#xff0c;可满足高性能计算、A…...

VSCode|IDEA|PyCharm无缝接入DeepSeek R1实现AI编程

文章目录 前言一、流程简介1. 获取DeepSeek R1的API密钥2. 在编程软件中下载安装 Continue 插件**IDEA**PyCharm 3. 配置Continue文件 二、使用体验利用 DeepSeek R1进行 AI 编程 前言 本文将介绍如何在 VSCode|IDEA|PyCharm 软件中接入 DeepSeek R1 实现 AI 编程&#xff0c;…...

深入浅出 PostgreSQL:从历史演进到高阶优化技术

引言 PostgreSQL 是一个免费开源的对象关系型数据库&#xff0c;既支持传统的 SQL 查询&#xff0c;也支持 JSON 等非关系数据类型&#xff0c;因其高度可扩展性和社区活跃度&#xff0c;已成为众多互联网、金融和企业级应用的首选数据库 (Introduction to PostgreSQL - W3Sch…...

塔能水泵节能方案:精准驱动工厂能耗优化

在工厂的能源消耗体系中&#xff0c;水泵作为关键的动力设备&#xff0c;其运行效率直接关系到整体能耗水平。传统水泵在长期运行中&#xff0c;受设计局限、工艺成本约束等因素影响&#xff0c;普遍存在效率低下、能源浪费严重的问题。塔能科技针对这一痛点&#xff0c;推出了…...

SSCLMD模型代码实现详解

SSCLMD模型代码实现详解 1. 项目源码结构 SSCLMD项目的源码结构如下&#xff1a; SSCLMD-main/ ├── README.md ├── ST4.xlsx ├── Supplementary File.docx ├── code/ │ ├── calculating_similarity.py │ ├── data_preparation.py │ ├── data_…...

【coze】故事卡片(图片、音频、文字)

【coze】故事卡片&#xff08;图片、音频、文字&#xff09; 1、创建智能体2、添加人设与回复逻辑3、添加工作流&#xff08;1&#xff09;创建工作流&#xff08;2&#xff09;添加大模型节点&#xff08;3&#xff09;添加提示词优化节点&#xff08;4&#xff09;添加豆包图…...

限免开关实施版本保护措施,保证项目灰度发布安全

迭代用户限免权限校验业务 新增限免开关实现普通用户权益更新&#xff0c;实施版本保护措施&#xff0c;保证项目灰度发布安全&#xff1b; // 是否展示限免标识 func (t *BasePrivilegeService) IsPromotionFree(p consumParams) bool {// 限免开关isFreeUseOpen : p.cfg.Vip…...

C#中从本地(两个路径文件夹)中实时拿图显示到窗口中并接收(两个tcp发送的信号)转为字符串显示在窗体中实现检测可视化

多窗口源码 C#中从本地&#xff08;两个路径文件夹&#xff09;中实时拿图显示到窗口中并接收&#xff08;两个tcp发送的信号&#xff09;转为字符串显示在窗体中实现检测可视化资源-CSDN文库 读图结果展示 字符串结果展示 利用TCP调试工具创建两个tcp 再次启动程序 就链接…...

了解一下OceanBase中的表分区

OceanBase 是一个高性能的分布式关系型数据库&#xff0c;它支持 SQL 标准的大部分功能&#xff0c;包括分区表。分区表可以帮助管理大量数据&#xff0c;提高查询效率&#xff0c;通过将数据分散到不同的物理段中&#xff0c;可以减少查询时的数据扫描量。 在 OceanBase 中操…...

生成了一个AI算法

import torch import torch.nn as nn import torch.optim as optim from torchvision import datasets, transforms # 1. 数据预处理 transform transforms.Compose([ transforms.ToTensor(), transforms.Normalize((0.5,), (0.5,)) # MNIST单通道归一化 ]) train_da…...

C# 使用SunnyUI控件 (VS 2019)

前言&#xff1a;建议下载源码&#xff0c;源码中包含了各种控件的用法案例。 下载 帮助文档: 文档预览 - Gitee.comGitee: SunnyUI: SunnyUI.NET 是基于.NET Framework 4.0、.NET8、.NET9 框架的 C# WinForm UI、开源控件库、工具类库、扩展类库、多页面开发框架。GitHub: h…...

在 Win11 下安装 Wireshark 的详细步骤

目录 一、了解 Wireshark1. 作用和功能2. 使用步骤 二、下载安装包三、运行安装包四、使用 Wireshark1. 抓包2. 窗口介绍3. 过滤器&#xff08;显示 / 捕获过滤器&#xff09;4. 保存过滤后的报文1&#xff09;显示过滤器表达式2&#xff09;过滤表达式的规则 5. 封包列表6. 封…...

【AI提示词】六顶思考帽工具专家

提示说明 提供专业的六顶思考帽工具应用服务&#xff0c;帮助用户从多角度进行创新性问题解决。 提示词 # Role: 六顶思考帽工具专家## Profile - language: 中文 - description: 提供专业的六顶思考帽工具应用服务&#xff0c;帮助用户从多角度进行创新性问题解决 - backgr…...

解锁RAG:AI 2.0时代的“知识外挂”是如何炼成的?

——从原理到实战&#xff0c;揭秘检索增强生成如何颠覆传统AI 引言&#xff1a;当AI学会“开卷考试” 如果传统大模型是“闭卷学霸”&#xff0c;那RAG&#xff08;Retrieval-Augmented Generation&#xff0c;检索增强生成&#xff09;就是那个考试时带着“百科全书”的超级…...

使用 ANSYS SIwave 求解器在 ANSYS AEDT 中预测串行通道性能并生成眼图

PCB 仿真 如今&#xff0c;无线射频设备日益复杂&#xff0c;对大型复杂 PCB 设计进行准确、高效仿真的需求也随之增加。在设计流程的早期识别和预测潜在问题可以节省资源、时间和金钱。SIwave 可帮助您对现代高性能电子产品中典型的高速通道和完整的输电系统进行建模、仿真和…...

启发式算法-模拟退火算法

模拟退火算法是一种基于概率的启发式优化算法&#xff0c;用于解决大规模组合优化问题&#xff0c;其灵感来源于金属退火过程中的物理现象。其基本原理是从一个初始解开始&#xff0c;然后在当前解的邻域内随机生成一个新解&#xff0c;如果新解的目标函数值优于当前解&#xf…...

机器视觉框架源码——解读3(常用的资源和样式)

这是关于框架解读的第三篇文章,将结合理论和框架代码进行讲解。 WPF中的各类工件元素,都可以设置其样式,如: 字体(FontFamily) 字体大小(FontSize) 背景颜色(Backgroud) 字体颜色(Foreground) 边距(Margin) 水平位置(HorizontalAlignment) 垂直位置(VerticalAlignment) 而样…...

勒索病毒肆虐时代:数据库加密存储的实践指南

在2025年第一季度&#xff0c;全球勒索攻击损失突破150亿美元&#xff0c;某跨国制造企业因数据库未加密被勒索3000枚比特币&#xff0c;某省级医保系统遭攻击导致参保人信息泄露……当医疗数据、金融资产、知识产权成为黑客的提款机&#xff0c;数据库加密已从技术选项升级为生…...

next中的server comonent中如何共享session

在 Next.js 的服务器组件&#xff08;Server Components&#xff09;里共享会话&#xff08;session&#xff09;&#xff0c;可以借助第三方库&#xff08;如 next-auth 或 express-session 结合自定义 API 路由&#xff09;来实现&#xff0c;下面为你详细介绍这两种常见的实…...

Desfire Ev1\Ev2\Ev3卡DES\3K3DES\AES加解密读写VB.Net示例源码

本示例使用发卡器&#xff1a;https://item.taobao.com/item.htm?spma21dvs.23580594.0.0.1d292c1bSxJTb6&ftt&id917152255720 Public Class Form1Public Declare Function pcdbeep Lib "OUR_MIFARE.dll" (ByVal xms As Integer) As BytePublic Declare Fu…...

商业实战将归巢网内容构建为本地RAG模型的完整指南01-优雅草卓伊凡

商业实战将归巢网内容构建为本地RAG模型的完整指南01-优雅草卓伊凡 今天卓伊凡收到了老客户归巢网关于对本地RAG模型建立的咨询&#xff0c;这点也让卓伊凡得深入研究下&#xff0c;毕竟老客户肯定不是说着玩的&#xff0c;主要最终实现目的是建立模型开始使用AI智能问答。 一…...

langchain4j整合springboot

环境介绍 JDK17Spring Boot: 3.0.2 创建springboot工程 IDEA新建一个springboot项目&#xff0c;使用Spring lnitializr快速构建。 选择Spring Boot: 3.0.2以及Spring Web依赖 添加maven依赖 创建完springboot项目之后&#xff0c;在pom中添加关键依赖 <properties&g…...

在线时间戳转换工具

给大家推荐一个在线时间戳转换工具 点击跳转-鸽鸽在线工具 这个工具除了时间戳转换&#xff0c;到首页还能选择使用很多其他小工具&#xff0c;欢迎使用...

Codeforces Round 1023 (Div. 2) (A-D)

每周至少五篇博客&#xff1a;(1/5) A. LRC and VIP 题意 您有一个大小 n n n 的数组 a a a - a 1 , a 2 , … a n a_1, a_2, \ldots a_n a1​,a2​,…an​ 。 您需要将 n n n 元素分为 2 2 2 序列 B B B 和 C C C &#xff0c;以满足以下条件&#xff1a; 每个元素…...

[Survey]Remote Sensing Temporal Vision-Language Models: A Comprehensive Survey

BaseInfo TitleRemote Sensing Temporal Vision-Language Models: A Comprehensive SurveyAdresshttps://arxiv.org/abs/2412.02573Journal/Time2024 arxivAuthor北航 上海AI LabCodehttps://github.com/Chen-Yang-Liu/Awesome-RS-Temporal-VLM 1. Introduction 传统遥感局限…...

Linux56 YUM源配置

epel未启动 显示系统未通过注册 配置YUM仓库 本地YUM仓库 1.备份 tar -zcf repo.tar.gz *.repo 2.挂载 mount -o ro /dev/sr0 /mnt 3.开机自启 chmod x /etc/rc.local echo ‘mount -o ro /dec/sr0 /mnt’ /etc/rc.local 4.编写本地YUM仓库 local.repo [local] namelocal yum …...

mysql 如何查询数据库链接日志

1&#xff0c;查看是否开启日志 SHOW GLOBAL VARIABLES LIKE general_log; -- 查看是否开启通用查询日志&#xff08;包括连接记录&#xff09; 1.1&#xff0c;假如没开启&#xff0c;可以临时开启&#xff0c;做测试&#xff1b;服务重启&#xff0c;配置失效&#xf…...

Element-Plus-X开源程序是Vue3 + Element-Plus 开箱即用的企业级AI组件库前端的解决方案

​一、软件介绍 文末提供程序和源码下载 Element-Plus-X开源程序是Vue3 Element-Plus 开箱即用的企业级AI组件库前端的解决方案。 二、核心特性 ✨ 企业级 AI 组件&#xff1a;内置聊天机器人、语音交互等场景化组件&#x1f680; 零配置集成&#xff1a;基于 Element-Plus …...

基于DevSecOps敏捷框架的数字供应链安全应解决方案

基于DevSecOps敏捷框架的数字供应链安全应解决方案是以“AI智能代码疫苗技术”深度赋能原创专利级“多模态SCADevSecOpsSBOM情报预警”的第四代DevSecOps数字供应链安全管理体系,在DevSecOps敏捷安全体系建设、数字供应链安全审查、开源供应链安全治理和云原生安全体系建设四大…...

2025年北京市职工职业技能大赛第六届信息通信行业网络安全技能大赛初赛-wp

- -考试当场没做出来 后面做的 misc ❯ cd misc ❯ ls num.docx num.zip ❯ unzip num.docx Archive: num.docxinflating: [Content_Types].xmlinflating: _rels/.relsinflating: word/document.xmlinflating: word/_rels/document.xml.relsextracting: word/media/image1.jp…...

2、实验室测控系统 - /自动化与控制组件/lab-monitoring-system

76个工业组件库示例汇总 实验室测控系统开发组件 这是一个专为实验室设备数据采集与分析设计的可视化测控系统组件。采用工业风格界面设计&#xff0c;提供了丰富的动态数据展示与分析功能&#xff0c;可应用于各类实验室环境中的设备监控和数据处理。 功能特点 多设备管理…...

Blender插件机制设计与Python实现

Blender插件机制设计与Python实现 Blender的插件机制是其强大扩展性的核心&#xff0c;允许开发者通过Python创建自定义功能。下面我将详细介绍Blender插件系统的设计原理&#xff0c;并提供一个完整的示例。 Blender插件系统设计原理 模块化架构&#xff1a;Blender将插件作…...

自定义一个 Spring Boot Starter -笔记

SpringBoot Starter的介绍参考&#xff1a; Spring Boot Starter简介-笔记-CSDN博客。这里介绍如何自定义一个springBoot Starter。 1. 项目结构 创建一个 Maven 项目&#xff0c;结构如下&#xff1a; custom-spring-boot-starter-demo/ ├── custom-hello-jdk/ # jdk模…...

【Part 2安卓原生360°VR播放器开发实战】第三节|实现VR视频播放与时间轴同步控制

《VR 360全景视频开发》专栏 将带你深入探索从全景视频制作到Unity眼镜端应用开发的全流程技术。专栏内容涵盖安卓原生VR播放器开发、Unity VR视频渲染与手势交互、360全景视频制作与优化&#xff0c;以及高分辨率视频性能优化等实战技巧。 &#x1f4dd; 希望通过这个专栏&am…...

读 书 说

好久没有坐下来手敲打字去输出或者记录分享一些比较正式的事情。 今天节后综合征&#xff0c;虽然我已经加了两天班了&#xff0c;但是还是不想加班便准点下班了。 今天来聊聊看书。 为什么会看书&#xff1f;最开始正如我之前提到过&#xff0c;人脉资源不多&#xff0c;也不…...

DOCX转PDF怎么操作最简单?快速将DOCX转换为专业PDF文档

在日常办公或学习中&#xff0c;我们经常需要将 Word 文档&#xff08;.docx格式&#xff09;转换为 PDF 文件。这不仅有助于保持文档格式的一致性&#xff0c;还能确保接收者无需特定软件即可查看文件内容。本文将详细介绍几种常见的方法来实现从 DOCX 到 PDF 的转换&#xff…...

免费轻量化办公pdf修改软件 一键格式转换基础修改到高级加密

各位办公软件小能手们&#xff01;今天咱来聊聊一款超厉害的 PDF 编辑软件——PDFXEdit。你知道吗&#xff0c;这软件就像个 PDF 处理的超级魔法师&#xff0c;能全方位搞定 PDF 文档。下面我就给大家详细说说它的那些功能和适用场景。 首先是基础编辑功能。这软件在文本与图像…...

【HFP】蓝牙语音通信高级功能解析:快速拨号与呼叫等待协议实现

在蓝牙语音通信系统中&#xff0c;除了基础的通话建立与控制流程&#xff0c;高级功能如快速拨号&#xff08;内存拨号、最后号码重拨&#xff09;和呼叫等待通知的实现&#xff0c;直接影响着用户体验的便捷性与系统的实用性。这些功能依赖于蓝牙协议中特定的 AT 命令交互、状…...

CVE-2025-24813:Apache Tomcat RCE 漏洞分析

CVE-2025-24813 是 Apache Tomcat 中的一个严重远程代码执行 (RCE) 漏洞,源于路径等效缺陷,允许攻击者绕过安全约束并远程执行任意代码。 CYFIRMA 的研究发现了一些活跃的漏洞利用,一些 PoC 漏洞在地下论坛上流传。攻击者利用基于 HTTP PUT 的任意文件上传、NTFS 连接漏洞利…...

神经网络之训练的艺术:反向传播与常见问题解决之道

神经网络训练的艺术&#xff1a;反向传播与常见问题解决之道 摘要 神经网络是现代机器学习的核心工具之一&#xff0c;而反向传播则是其训练过程中不可或缺的算法。本文深入探讨了反向传播的工作原理以及在训练过程中常见的问题&#xff0c;如梯度消失、梯度爆炸、死 ReLU 单…...

小土堆pytorch--transform

torchvision中的transform torchvision中的transform1. transforms的使用1.1 transforms的结构及用法理论1.2 相应代码1.3 对上述代码的解释 2. 常见的transforms2.1 python 的call函数2.2 ToTensor的使用2.3 Normalize的使用2.4 Resize的使用2.5 Compose的使用2.6 RandomCrop的…...

【Django】REST 常用类

ModelSerializer serializers.ModelSerializer 是 Django REST framework&#xff08;DRF&#xff09;里的一个强大工具&#xff0c;它能极大简化序列化和反序列化 Django 模型实例的流程。下面从多个方面详细介绍它&#xff1a; 1. 基本概念 序列化是把 Django 模型实例转化…...