深入理解Java阻塞队列:原理、使用场景及代码实战
🚀 文章提示
你将在这篇文章中收获:
阻塞队列的核心特性:队列空/满时的阻塞机制
四种操作方式对比:抛异常、返回特殊值、永久阻塞、超时阻塞
SynchronousQueue的独特设计:同步队列的生产者-消费者强耦合
代码实战:通过20+个案例彻底掌握阻塞队列的API
目录
🚀 文章提示
🌟 前言
📚 一、阻塞队列的本质
阻塞队列 = 普通队列 + 线程协调机制
BlockingQueue BlockingQueue 不是新的东西
为什么需要阻塞队列?
🔧 二、四大核心操作API对比
1. 抛异常型(新手慎用)
2. 返回特殊值型(推荐基础使用)
3. 永久阻塞型(线程池底层使用)
4. 超时阻塞型(高并发推荐)
🎯 三、阻塞队列分类及选型
💡 四、SynchronousQueue深度解析
1.同步队列的三大特征:
2.代码演示:订单即时处理系统
代码示例:
输出结果分析:
🚨 五、避坑指南
🌈 六、实战应用场景
线程池任务队列
生产者-消费者日志系统
🎓 总结与提升
基础选择原则
进阶使用技巧
性能优化方向
🌟 前言
在多线程编程中,线程间的高效通信是保证程序正确性的关键。想象一个外卖配送场景:骑手(生产者)不断接单,商家(消费者)按顺序处理订单。如果订单爆单时骑手还在盲目塞单,或者无单时商家不停空跑,都会造成系统崩溃。
这正是 阻塞队列(BlockingQueue) 要解决的核心问题!它像一座智能缓冲桥梁,让生产者和消费者线程安全、高效地协作。本文将用最通俗的案例+代码,带你彻底掌握这个并发编程利器。
📚 一、阻塞队列的本质
阻塞队列 = 普通队列 + 线程协调机制
-
队列空时:消费者线程自动挂起,直到有数据
-
队列满时:生产者线程自动挂起,直到有空位
-
自带线程唤醒机制:无需手动wait/notify
BlockingQueue BlockingQueue 不是新的东西

为什么需要阻塞队列?
什么情况下我们会使用 阻塞队列:多线程并发处理,线程池!
场景 | 传统实现痛点 | 阻塞队列解决方案 |
---|---|---|
生产者速度 > 消费者 | 队列爆满导致数据丢失 | 自动阻塞生产者线程 |
消费者速度 > 生产者 | 空轮询消耗CPU资源 | 自动挂起消费者线程 |
流量突增 | 需要手动扩容/限流 | 内置容量控制机制 |
🔧 二、四大核心操作API对比
以ArrayBlockingQueue为例,演示不同操作方式:
方式 | 抛出异常 | 有返回值,不抛出异常 | 阻塞 等待 | 超时等待 |
---|---|---|---|---|
添加 | add | offer() | put() | offer(,,) |
移除 | remove | poll() | take() | poll(,) |
检测队首元素 | element | peek | - |
1. 抛异常型(新手慎用)
public static void testThrowException() {BlockingQueue<String> queue = new ArrayBlockingQueue<>(3);System.out.println(queue.add("A")); // trueSystem.out.println(queue.add("B")); // trueSystem.out.println(queue.add("C")); // truequeue.add("D"); // 抛出IllegalStateExceptionSystem.out.println(queue.remove()); // ASystem.out.println(queue.remove()); // BSystem.out.println(queue.remove()); // Cqueue.remove(); // 抛出NoSuchElementException
}
2. 返回特殊值型(推荐基础使用)
public static void testReturnSpecial() {BlockingQueue<String> queue = new ArrayBlockingQueue<>(3);System.out.println(queue.offer("A")); // trueSystem.out.println(queue.offer("B")); // trueSystem.out.println(queue.offer("C")); // trueSystem.out.println(queue.offer("D")); // false (静默失败)System.out.println(queue.poll()); // ASystem.out.println(queue.poll()); // BSystem.out.println(queue.poll()); // CSystem.out.println(queue.poll()); // null
}
3. 永久阻塞型(线程池底层使用)
public static void testForeverBlock() throws InterruptedException {BlockingQueue<String> queue = new ArrayBlockingQueue<>(3);queue.put("A"); // 成功queue.put("B"); // 成功queue.put("C"); // 成功queue.put("D"); // 线程在此处永久挂起!!System.out.println(queue.take()); // ASystem.out.println(queue.take()); // BSystem.out.println(queue.take()); // CSystem.out.println(queue.take()); // 永久等待新元素...
}
4. 超时阻塞型(高并发推荐)
public static void testTimeoutBlock() throws InterruptedException {BlockingQueue<String> queue = new ArrayBlockingQueue<>(3);System.out.println(queue.offer("A", 2, TimeUnit.SECONDS)); // trueSystem.out.println(queue.offer("B", 2, TimeUnit.SECONDS)); // trueSystem.out.println(queue.offer("C", 2, TimeUnit.SECONDS)); // trueSystem.out.println(queue.offer("D", 2, TimeUnit.SECONDS)); // 2秒后返回falseSystem.out.println(queue.poll(2, TimeUnit.SECONDS)); // ASystem.out.println(queue.poll(2, TimeUnit.SECONDS)); // BSystem.out.println(queue.poll(2, TimeUnit.SECONDS)); // CSystem.out.println(queue.poll(2, TimeUnit.SECONDS)); // 等待2秒后返回null
}
完整代码:
package JUC.bq;import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.SynchronousQueue;
import java.util.concurrent.TimeUnit;public class Test {public static void main(String[] args) {test1();}/*** 抛出异常*/public static void test1() {// 队列的大小创建阻塞队列ArrayBlockingQueue blockingQueue = new ArrayBlockingQueue<>(3);//队列大小System.out.println(blockingQueue.add("a"));System.out.println(blockingQueue.add("b"));System.out.println(blockingQueue.add("c"));// IllegalStateException: Queue full 抛出异常!// System.out.println(blockingQueue.add("d"));System.out.println("===============");System.out.println(blockingQueue.remove());System.out.println(blockingQueue.remove());System.out.println(blockingQueue.remove());// java.util.NoSuchElementException 抛出异常!// System.out.println(blockingQueue.remove());}/*** 有返回值,没有异常*/public static void test2() {// 队列的大小ArrayBlockingQueue blockingQueue = new ArrayBlockingQueue<>(3);System.out.println(blockingQueue.offer("a"));System.out.println(blockingQueue.offer("b"));System.out.println(blockingQueue.offer("c"));// System.out.println(blockingQueue.offer("d")); // false 不抛出异常!System.out.println("============================");System.out.println(blockingQueue.poll());System.out.println(blockingQueue.poll());System.out.println(blockingQueue.poll());System.out.println(blockingQueue.poll()); // null 不抛出异常!}/*** 等待,阻塞(一直阻塞)*/public static void test3() throws InterruptedException {// 队列的大小ArrayBlockingQueue blockingQueue = new ArrayBlockingQueue<>(3);// 一直阻塞blockingQueue.put("a");blockingQueue.put("b");blockingQueue.put("c");// blockingQueue.put("d"); // 队列没有位置了,一直阻塞System.out.println(blockingQueue.take());System.out.println(blockingQueue.take());System.out.println(blockingQueue.take());System.out.println(blockingQueue.take()); // 没有这个元素,一直阻塞}/*** 等待,阻塞(等待超时)*/public static void test4() throws InterruptedException {// 队列的大小ArrayBlockingQueue blockingQueue = new ArrayBlockingQueue<>(3);blockingQueue.offer("a");blockingQueue.offer("b");blockingQueue.offer("c");// blockingQueue.offer("d",2,TimeUnit.SECONDS); // 等待超过2秒就退出System.out.println("===============");System.out.println(blockingQueue.poll());System.out.println(blockingQueue.poll());System.out.println(blockingQueue.poll());blockingQueue.poll(2, TimeUnit.SECONDS); // 等待超过2秒就退出}
}
🎯 三、阻塞队列分类及选型
队列类型 | 特性 | 适用场景 |
---|---|---|
ArrayBlockingQueue | 数组实现,固定容量 | 已知固定并发量的生产消费模型 |
LinkedBlockingQueue | 链表实现,可选容量(默认Integer.MAX) | 高吞吐量场景 |
SynchronousQueue | 无缓冲队列,直接传递 | 线程间精准握手(AQS底层实现) |
PriorityBlockingQueue | 优先级排序 | 任务优先级调度系统 |
DelayQueue | 延迟执行队列 | 定时任务调度 |
💡 四、SynchronousQueue深度解析
1.同步队列的三大特征:
-
容量始终为0,不能提前存储元素
-
put操作必须等待take操作,反之亦然
-
适合传递性任务(线程间直接交接数据)
- 进去一个元素,必须等待取出来之后,才能再往里面放一个元素!
2.代码演示:订单即时处理系统
public class SynchronousQueueDemo {public static void main(String[] args) {BlockingQueue<String> syncQueue = new SynchronousQueue<>();// 厨师线程(生产者)new Thread(() -> {try {System.out.println("厨师接到订单:汉堡");syncQueue.put("汉堡"); // 等待骑手取餐System.out.println("厨师接到订单:薯条");syncQueue.put("薯条");System.out.println("厨师接到订单:可乐");syncQueue.put("可乐");} catch (InterruptedException e) {e.printStackTrace();}}, "厨师线程").start();// 骑手线程(消费者)new Thread(() -> {try {TimeUnit.SECONDS.sleep(3);System.out.println("骑手取到:" + syncQueue.take());TimeUnit.SECONDS.sleep(2);System.out.println("骑手取到:" + syncQueue.take());TimeUnit.SECONDS.sleep(1);System.out.println("骑手取到:" + syncQueue.take());} catch (InterruptedException e) {e.printStackTrace();}}, "骑手线程").start();}
}
代码示例:
package JUC.bq;import java.sql.Time;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.SynchronousQueue;
import java.util.concurrent.TimeUnit;
/*** 同步队列* 和其他的BlockingQueue 不一样, SynchronousQueue 不存储元素* put了一个元素,必须从里面先take取出来,否则不能在put进去值!*/
public class SynchronousQueueDemo {public static void main(String[] args) {BlockingQueue<String> blockingQueue = new SynchronousQueue<>(); // 同步队列new Thread(()->{try {System.out.println(Thread.currentThread().getName()+" put 1");blockingQueue.put("1");System.out.println(Thread.currentThread().getName()+" put 2");blockingQueue.put("2");System.out.println(Thread.currentThread().getName()+" put 3");blockingQueue.put("3");} catch (InterruptedException e) {e.printStackTrace();}},"T1").start();new Thread(()->{try {TimeUnit.SECONDS.sleep(3);System.out.println(Thread.currentThread().getName()+"=>"+blockingQueue.take());TimeUnit.SECONDS.sleep(3);System.out.println(Thread.currentThread().getName()+"=>"+blockingQueue.take());TimeUnit.SECONDS.sleep(3);System.out.println(Thread.currentThread().getName()+"=>"+blockingQueue.take());} catch (InterruptedException e) {e.printStackTrace();}},"T2").start();}
}
输出结果分析:
厨师接到订单:汉堡 // 厨师开始制作汉堡 (等待3秒) 骑手取到:汉堡 // 骑手取走汉堡 厨师接到订单:薯条 // 厨师立即开始做薯条 (等待2秒) 骑手取到:薯条 // 取走薯条 厨师接到订单:可乐 // 开始做可乐 (等待1秒) 骑手取到:可乐 // 最后取可乐
🚨 五、避坑指南
-
容量选择:LinkedBlockingQueue默认长度是Integer.MAX_VALUE(约21亿),可能引发OOM
-
方法混淆:poll()与take()要根据是否需要永久等待来选择
-
公平性设置:ArrayBlockingQueue构造函数可设置公平锁,避免线程饥饿
-
异常处理:永远不要忽略offer/poll返回的boolean结果
🌈 六、实战应用场景
线程池任务队列
// ThreadPoolExecutor的第五个参数就是BlockingQueue
ExecutorService pool = new ThreadPoolExecutor(2, // 核心线程数5, // 最大线程数60L, TimeUnit.SECONDS,new LinkedBlockingQueue<>(100) // 任务队列
);
生产者-消费者日志系统
// 日志缓存队列
BlockingQueue<LogMessage> logQueue = new ArrayBlockingQueue<>(500);// 生产者(多个业务线程)
public void log(String message) {logQueue.offer(new LogMessage(message, System.currentTimeMillis()));
}// 消费者(专用日志线程)
class LogConsumer implements Runnable {@Overridepublic void run() {while(true) {try {LogMessage log = logQueue.take();writeToDisk(log); // 实际写入操作} catch (InterruptedException e) {Thread.currentThread().interrupt();}}}
}
🎓 总结与提升
阻塞队列的本质是线程间的通信工具,它通过智能的阻塞/唤醒机制,完美解决了生产者和消费者的速度匹配问题。通过本文的4种API对比+5种队列类型解析+真实场景案例,你应该已经掌握了:
基础选择原则
-
需要快速失败选
offer()/poll()
-
需要资源保护选
put()/take()
-
精准控制用超时API
进阶使用技巧
-
SynchronousQueue适合线程间直接传递数据的场景(如Executors.newCachedThreadPool)
-
PriorityBlockingQueue实现VIP客户优先处理
-
使用DelayQueue做定时任务调度(比Timer更安全)
性能优化方向
-
监控队列的
remainingCapacity()
提前预警 -
使用
drainTo()
方法批量处理元素提升吞吐量 -
结合Guava的Queues工具类进行高级操作
最后思考:当使用put()方法阻塞时,如何优雅地终止线程?欢迎在评论区分享你的方案!
相关文章:
深入理解Java阻塞队列:原理、使用场景及代码实战
🚀 文章提示 你将在这篇文章中收获: 阻塞队列的核心特性:队列空/满时的阻塞机制 四种操作方式对比:抛异常、返回特殊值、永久阻塞、超时阻塞 SynchronousQueue的独特设计:同步队列的生产者-消费者强耦合 代码实战&a…...
vue3--手写手机屏组件
<!--* 手机预览* Author: Hanyang* Date: 2022-12-09 09:13:00* LastEditors: Hanyang* LastEditTime: 2023-01-12 15:37:00 --> <template><divclass"public-preview-mobile"ref"previewMobileRef":class"showMobile ? animation-sh…...
【Elasticsearch】入门篇
Elasticsearch 入门 前言 官方地址:Elastic — 搜索 AI 公司 | Elastic ES 下载地址:Past Releases of Elastic Stack Software | Elastic 文档:什么是 Elasticsearch?|Elasticsearch 指南 简介 Elasticsearch 是一个分布式、…...
Unity 使用 ADB 实时查看手机运行性能
Unity 使用 ADB 实时查看手机运行性能 前言操作步骤ADB工具下载ADB工具配置手机进入开发者模式并开启USB调试使用ADB连接手机Unity打包设置使用Profiler实时查看性能情况优化建议 常见问题 前言 通过 ADB(Android Debug Bridge)连接安卓设备,…...
蓝桥杯 1. 四平方和
四平方和 原题目链接 题目描述 四平方和定理(又称拉格朗日定理)指出: 每个正整数都可以表示为 至多 4 个正整数的平方和。 如果将 0 包括进去,则每个正整数都可以恰好表示为 4 个非负整数的平方和。 例如: 5 0 …...
Nginx 配置参数全解版:Nginx 反向代理与负载均衡;Nginx 配置规范与 Header 透传实践指南;Nginx 配置参数详解
Nginx 配置参数全解版:Nginx 反向代理与负载均衡;Nginx 配置规范与 Header 透传实践指南;Nginx 配置参数详解 Nginx 反向代理与负载均衡配置,Header 透传到后端应用(参数全解版)一、Nginx 反向代理与负载均…...
数据分析之技术干货业务价值 powerquery 分组排序后取TOP
在电商中,我们要对货品进行分析,由于所有的销售数据都在一起,货品信息也在一起,两个表建立了关系之后,要看每个品类的TOP款有哪些,每个品类的TOP款是什么要怎么做呢? 下面是我做数据的思路&…...
windows中kafka4.0集群搭建
参考文献 Apache Kafka windows启动kafka4.0(不再需要zookeeper)_kafka压缩包-CSDN博客 Kafka 4.0 KRaft集群部署_kafka4.0集群部署-CSDN博客 正文 注意jdk需要17版本以上的 修改D:\software\kafka_2.13-4.0.0\node1\config\server.properties配置文…...
数据分析案例:医疗健康数据分析
目录 数据分析案例:医疗健康数据分析1. 项目背景2. 数据加载与预处理2.1 加载数据2.2 数据清洗3. 探索性数据分析(EDA)3.1 再入院率概览3.2 按年龄分组的再入院率3.3 住院时长与再入院4. 特征工程与可视化5. 模型构建与评估5.1 数据划分5.2 训练逻辑回归5.3 模型评估6. 业务…...
数据分析之 商品价格分层之添加价格带
在分析货品数据的时候,我们会对商品的价格进行分层汇总,也叫价格带, 一、价格带的定义 价格带(Price Band):将商品按价格区间划分(如0-50元、50-100元、100-200元等ÿ…...
跨浏览器音频录制:实现兼容的音频捕获与WAV格式生成
在现代Web开发中,音频录制功能越来越受到开发者的关注。无论是在线会议、语音识别还是简单的语音留言,音频录制都是一个重要的功能。然而,实现一个跨浏览器的音频录制功能并非易事,因为不同浏览器对音频录制API的支持存在差异。本…...
JavaScript 的“世界模型”:深入理解对象 (Objects)
引言:超越简单值,构建复杂实体 到目前为止,我们学习的变量大多存储的是单一的值,比如一个数字 (let age 30;)、一个字符串 (let name "Alice";) 或一个布尔值 (let isActive true;)。这对于简单场景足够了&am…...
【国产化之路】VPX-3U :基于D2000 /FT2000的硬件架构到操作系统兼容
在国产化和高性能计算、嵌入式系统领域日益受到重视的今天,VPX3U架构以其标准化和模块化的特性广受关注。本文将从硬件架构、系统软件、接口拓展及典型应用等方面,深入剖析整体设计思路与工程实现,供友友们参考和讨论。 一、总体架构与设计目…...
深入探索RAG(检索增强生成)模型的优化技巧
📌 友情提示: 本文内容由银河易创AI(https://ai.eaigx.com)创作平台的gpt-4o-mini模型生成,旨在提供技术参考与灵感启发。文中观点或代码示例需结合实际情况验证,建议读者通过官方文档或实践进一步确认其准…...
架构-软件架构设计
一、软件架构基础概念 1. 软件架构的定义 通俗理解:软件架构是软件系统的“骨架”,定义了系统的结构、行为和属性,就像盖房子的设计图纸,规划了房间布局、承重结构和功能分区。核心作用: 沟通桥梁:让技术…...
免费的 HTML 网页托管服务
字根云平台最近上线了一项新的服务: HTML 网页托管。 HTML 网页免费托管 免费HTML静态页面文件托管-字根秀秀 www.cuobiezi.net/showshow/ 网页托管主要支持的功能: 1. 托管静态的 HTML 网页(不包含图片,图片请使用专业图床&a…...
Ubuntu服务器上如何监控Oracle数据库
在 Ubuntu 服务器上监控 Oracle 数据库,虽然不像在 Windows 或某些企业 Linux(如 RHEL)那样有现成的 GUI 工具,但你完全可以通过命令行工具、脚本、开源监控平台来实现全面监控,包含: 数据库性能指标&#…...
什么是CMMI认证?CMMI评估内容?CMMI认证能带来哪些好处?
CMMI认证详解:概念、评估内容与核心价值 一、什么是CMMI认证? CMMI(Capability Maturity Model Integration,能力成熟度模型集成)是由美国卡内基梅隆大学软件工程研究所(SEI)开发的一套全球公…...
PySide6 GUI 学习笔记——常用类及控件使用方法(常用类矩阵QRectF)
文章目录 类描述构造方法主要方法1. 基础属性2. 边界操作3. 几何运算4. 坐标调整5. 转换方法6. 状态判断 类特点总结1. 浮点精度:2. 坐标系统:3. 有效性判断:4. 几何运算:5. 类型转换:6. 特殊处理: 典型应用…...
arm64适配系列文章-第五章-arm64环境上redis的部署
ARM64适配系列文章 第一章 arm64环境上kubesphere和k8s的部署 第二章 arm64环境上nfs-subdir-external-provisioner的部署 第三章 arm64环境上mariadb的部署 第四章 arm64环境上nacos的部署 第五章 arm64环境上redis的部署 第六章 arm64环境上rabbitmq-management的部署 第七章…...
Ubuntu / WSL 安装pipx
一、安装pipx 在 Ubuntu / WSL 上可以用两种方式安装,推荐第二种(官方脚本)或第三种(pip 安装最新版本并自动配置 PATH)。 1. apt 安装(最快,但版本往往偏旧) sudo apt update su…...
10天学会嵌入式技术之51单片机-day-6
第十五章 点阵LED 15.1 点阵 LED 概述 15.1.1 实物图 15.1.1 原理图 15.2 点阵 LED 静态显示 15.2.1 需求描述 使用点阵 LED 显示一排由左上到右下的斜线,具体效果如下图所示。 15.2.2 硬件设计 15.2.2.1 硬件原理图 根据内部原理可知,点阵 LED 的…...
【数据可视化-28】2017-2025 年每月产品零售价数据可视化分析
🧑 博主简介:曾任某智慧城市类企业算法总监,目前在美国市场的物流公司从事高级算法工程师一职,深耕人工智能领域,精通python数据挖掘、可视化、机器学习等,发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…...
【JavaScript】`Object` 对象静态方法详解
在 JavaScript 中,Object 对象提供了许多静态方法,用于操作和处理对象。以下是一些常用的 Object.xxx 方法及其用途和示例: 1. 属性相关方法 Object.keys(obj) 返回对象自身的所有可枚举属性的键组成的数组。 const obj = {a: 1, b: 2 }; console.log(Object.keys(obj)); //…...
音视频之H.265/HEVC量化
H.265/HEVC系列文章: 1、音视频之H.265/HEVC编码框架及编码视频格式 2、音视频之H.265码流分析及解析 3、音视频之H.265/HEVC预测编码 4、音视频之H.265/HEVC变换编码 5、音视频之H.265/HEVC量化 量化 (Quantization) 是指将信号的连续取值(或大量可能的离散取…...
Tomcat:从零理解Java Web应用的“心脏”
目录 一、Tomcat是什么?为什么需要它? 二、Tomcat的核心架构(餐厅运营图) 1. 两大核心组件 2. 请求处理全流程(从点餐到上菜) 三、手把手搭建第一个网站(厨房开张实录) 环境准备…...
第七届能源系统与电气电力国际学术会议(ICESEP 2025)
重要信息 时间:2025年6月20-22日 地点:中国-武汉 官网:www.icesep.net 主题 能源系统 节能技术、能源存储技术、可再生能源、热能与动力工程 、能源工程、可再生能源技术和系统、风力发…...
【基础】Node.js 介绍、安装及npm 和 npx功能了解
前言 后面安装n8n要用到,做一点技术储备。主要是它的两个工具:npm 和 npx。 Node.js介绍 Node.js 是一个免费的、开源的、跨平台的 JavaScript 运行时环境,允许开发人员在浏览器之外编写命令行工具和服务器端脚本,是一个基于 C…...
【硬核干货】SonarQube安全功能
原文链接:【硬核干货】SonarQube安全功能 关于晓数神州 晓数神州坚持以“客户为中心”的宗旨,为客户提供专业的解决方案和技术服务,构建多引擎数字化体系。 核心业务1:聚焦DevOps全栈产品,打造需求管理、项目管理、开…...
微信小程序 tabbar底部导航栏
官方文档:https://developers.weixin.qq.com/miniprogram/dev/reference/configuration/app.html#tabBar 一、常规菜单格式 在app.json 文件中配置,其他关键点详见官方文档,后续更新不规则图标的写法...
如何将极狐GitLab 议题导出为 CSV?
极狐GitLab 是 GitLab 在中国的发行版,关于中文参考文档和资料有: 极狐GitLab 中文文档极狐GitLab 中文论坛极狐GitLab 官网 导出议题到 CSV (BASIC ALL) 您可以将问题从极狐GitLab 导出为 CSV 文件,这些文件将作为附件发送到您的默认通知…...
nodejs之Express-介绍、路由
五、Express 1、express 介绍 express 是一个基于 Node.js 平台的极简、灵活的 WEB 应用开发框架,官方网址: https://www.expressjs.com.cn/ 简单来说,express 是一个封装好的工具包,封装了很多功能,便于我们开发 WEB 应用(HTTP 服务) (1)基本使用 第一步:初始化项目并…...
极狐GitLab 如何从 CSV 导入议题?
极狐GitLab 是 GitLab 在中国的发行版,关于中文参考文档和资料有: 极狐GitLab 中文文档极狐GitLab 中文论坛极狐GitLab 官网 从 CSV 导入议题 (BASIC ALL) 您可以通过上传包含以下列的 CSV 文件将议题导入项目: 名称是否必需?…...
JW01三合一传感器详解(STM32)
目录 一、介绍 二、传感器原理 1.原理图 2.引脚描述 三、程序设计 main文件 usart3.h文件 usart3.c文件 四、实验效果 五、资料获取 项目分享 一、介绍 JW01三合一检测模块是一种用于检测空气中二氧化碳浓度的传感器模块。它可以广泛应用于室内空气质量检测、智能家…...
23种设计模式-行为型模式之策略模式(Java版本)
Java 策略模式(Strategy Pattern)详解 🧠 什么是策略模式? 策略模式是一种行为型设计模式,它定义了一系列算法,把它们一个个封装起来,并且使它们可以互相替换。策略模式让算法独立于使用它的客…...
ActiveMQ 快速上手:安装配置与基础通信实践(一)
一、引言 在当今分布式系统和微服务架构盛行的时代,消息通信作为实现系统间解耦、异步处理和可靠传输的关键技术,显得尤为重要。ActiveMQ 作为一款广泛应用的开源消息中间件,凭借其对 JMS 规范的全面支持、丰富的特性以及出色的性能…...
究竟什么是自动化测试?
自动化测试是一种软件测试方法,旨在通过使用自动化工具和脚本来执行测试任务,以减少人工操作,提高测试效率和准确性。 以下是对自动化测试的详细介绍: 一、定义与特点 定义:自动化测试是指利用自动化工具和脚本来执…...
【LLM+Code】Github Copilot Agent/VsCode Agent 模式PromptTools详细解读
一、前言 github copilot agent mode现在和vscode是强绑定的关系, 其实是一个东西: https://github.blog/news-insights/product-news/github-copilot-the-agent-awakens/https://code.visualstudio.com/docs/copilot/chat/chat-agent-mode 二、Syste…...
IDEA将本地的JAR文件手动安装到 Maven的本地仓库
例如这是要导入的依赖: mvn install:install-file -DfileD:\aliyun-java-sdk-ding.jar -DgroupIdcom.aliyun -DartifactIdaliyun-java-sdk-ding -Dversion1.0.0 -Dpackagingjar-DfileD:\aliyun-java-sdk-ding.jar 含义:指定要安装到本地 Maven 仓库的 …...
redis集群的三种部署方式
一、主从同步 redis的主从同步工作原理简单概括为: 1、从服务器(Slave Server)向(主服务器,Master)发送sync(同步)命令 2、master启动后台存盘进程,并收集所有修改数据命令 3、master完成存盘后,传送整个数据文件到slave 4、slave接受数据文件,加载到内存中完成首次…...
【GIT】github中的仓库如何删除?
你可以按照以下步骤删除 GitHub 上的仓库(repository): 🚨 注意事项: ❗️删除仓库是不可恢复的操作,所有代码、issue、pull request、release 等内容都会被永久删除。 🧭 删除 GitHub 仓库步骤…...
CIFAR10图像分类学习笔记(三)---数据加载load_cifar10
新创建一个load_cifar10源文件 需要导入的包 import glob from torchvision import transforms from torch.utils.data import DataLoader ,Dataset import os #读取工具 from PIL import Image import numpy as np 01同样定义10个类别的标签名数组 label_name ["airpl…...
基于Matlab的车牌识别系统
1.程序简介 本模型基于MATLAB,通过编程创建GUI界面,基于Matlab的数字图像处理,对静止的车牌图像进行分割并识别,通过编写matlab程序对图像进行灰度处理、二值化、腐蚀膨胀和边缘化处理等,并定位车牌的文字,实现字符的…...
【农气项目】基于适宜度的产量预报
直接上干货(复制到开发工具即可运行的代码) 1. 适宜度模型及作物適宜度计算方法 2. 产量分离 3. 基于适宜度计算产量预报 1. 适宜度模型及作物適宜度计算方法 // 三基点温度配置private final double tempMin;private final double tempOpt;private f…...
C#中实现JSON解析器
JSON(JavaScript Object Notation)即 JavaScript 对象表示法,是一种轻量级的数据交换格式。 起源与发展 JSON 源于 JavaScript 编程语言,是 JavaScript 对象字面量语法的一个子集。但如今它已经独立于 JavaScript,成…...
Android studio进阶开发(四)--okhttp的网络通信的使用
我们之前学过了socket服务器,这次我们继续来学习网络热门编程http/https的使用与交互 1)什么是Http协议? 答:hypertext transfer protocol(超文本传输协议),TCP/IP协议的一个应用层协议&#x…...
untiy 实现点击按钮切换天空盒子
1.新建材质DaySkybox和NightSkybox 设置 Shader 为 Skybox/6 Sided 2.创建ui 切换按钮,编写天空 盒子的脚本 using UnityEngine; using UnityEngine.UI;public class SkyboxSwitcher : MonoBehaviour {public Material daySkybox; // 拖入白天的天空盒材质publi…...
Docker从0-1搭建个人云盘(支持Android iOS PC)
一、Docker位置配置【遇到再大的事,先备份MYSQL数据库,说了多少遍】 ******************************************************************************************************************************************* docker rm -f $(docker ps -a -q…...
Java Agent 注入 WebSocket 篇
Agent 如果要对其进行Agent注入的编写,需要先理解三个名字premain,agentmain,Instrumentation premain方法在 JVM 启动阶段调用,一般维持权限的时候不会使用 agentmain方法在 JVM 运行时调用 常用的 Instrumentation实例为代理…...
Linux:git和gdb/cgdb
一:在XShell上使用git 步骤1:安装git命令行 sudo yum install git 步骤2:注册git账户和仓库,并点击克隆/下载,把HTTPS复制 步骤3: 在显示屏上输入下面命令,然后按提示输入自己的用户名和邮箱…...