并发设计模式实战系列(16):屏障(Barrier)
🌟 大家好,我是摘星! 🌟
今天为大家带来的是并发设计模式实战系列,第十六章屏障(Barrier),废话不多说直接开始~
目录
一、核心原理深度拆解
1. 屏障的同步机制
2. 关键参数
二、生活化类比:团队登山
三、Java代码实现(生产级Demo)
1. 完整可运行代码
2. 关键方法说明
四、横向对比表格
1. 同步工具对比
2. 屏障参数配置对比
五、高级应用技巧
1. 多阶段任务控制
2. 动态线程管理
3. 性能监控
六、工程实践中的陷阱与解决方案
1. 死锁风险场景
2. 屏障断裂处理
七、性能优化技巧
1. 分层屏障设计
2. 与ForkJoinPool结合
八、分布式屏障扩展(ZooKeeper实现)
1. 核心原理
2. Java代码片段
九、监控与调试方案
1. 关键监控指标
2. Arthas诊断命令
十、与其他模式的组合应用
1. 屏障 + 生产者消费者模式
2. 代码示例
一、核心原理深度拆解
1. 屏障的同步机制
┌─────────────┐ ┌─────────────┐ ┌─────────────┐
│ 线程1 │ │ 线程2 │ │ 线程N │
│ 执行阶段1 │ │ 执行阶段1 │ │ 执行阶段1 │
└──────┬──────┘ └──────┬──────┘ └──────┬──────┘│ │ │└─────────┬────────┴────────┬─────────┘│ 屏障点 │▼ ▼┌───────────────────┐│ 所有线程到达后 ││ 才继续执行阶段2 │└───────────────────┘
- 协调机制:强制多个线程在某个点等待,直到所有参与线程都到达该点
- 重置特性:CyclicBarrier 可重复使用(自动重置),CountDownLatch 不可重置
2. 关键参数
- parties:需要等待的线程数量
- barrierAction:所有线程到达后触发的回调(可选)
二、生活化类比:团队登山
系统组件 | 现实类比 | 核心行为 |
线程 | 登山队员 | 各自以不同速度攀登 |
屏障点 | 集合点 | 必须所有队员到齐才能继续前进 |
barrierAction | 领队 | 检查装备、宣布下一阶段路线 |
- 异常处理:若有队员受伤(线程中断),其他队员需要决定是否继续等待
三、Java代码实现(生产级Demo)
1. 完整可运行代码
import java.util.concurrent.*;
import java.util.Random;public class BarrierPatternDemo {// 登山模拟static class MountainClimbing {private final CyclicBarrier barrier;private final Random rand = new Random();public MountainClimbing(int teamSize) {// 屏障点设置:队伍到齐后执行领队指令this.barrier = new CyclicBarrier(teamSize, () -> {System.out.println("\n=== 所有队员已到达集合点 ===");System.out.println("领队:检查装备完毕,向下一营地前进!");});}public void climb(String name) {try {// 第一阶段攀登int time = rand.nextInt(3000);System.out.printf("%s 正在攀登第一段(预计%dms)...\n", name, time);Thread.sleep(time);System.out.printf("[%s] 到达第一集合点,等待队友...\n", name);barrier.await(); // 等待所有队员// 第二阶段(屏障解除后)time = rand.nextInt(4000);System.out.printf("%s 向顶峰冲刺(预计%dms)...\n", name, time);Thread.sleep(time);System.out.printf("[%s] 成功登顶!\n", name);} catch (InterruptedException | BrokenBarrierException e) {System.out.printf("[%s] 登山中断: %s\n", name, e.getMessage());}}}public static void main(String[] args) {final int TEAM_SIZE = 3;MountainClimbing expedition = new MountainClimbing(TEAM_SIZE);// 创建登山线程ExecutorService pool = Executors.newFixedThreadPool(TEAM_SIZE);for (int i = 1; i <= TEAM_SIZE; i++) {String name = "队员-" + i;pool.execute(() -> expedition.climb(name));}pool.shutdown();}
}
2. 关键方法说明
// 1. 屏障等待(可设置超时)
barrier.await(5, TimeUnit.SECONDS);// 2. 检查屏障状态
barrier.isBroken(); // 是否有线程被中断
barrier.getNumberWaiting(); // 当前等待的线程数// 3. 重置屏障(CyclicBarrier特有)
barrier.reset();
四、横向对比表格
1. 同步工具对比
工具 | 可重用性 | 可中断 | 额外功能 | 适用场景 |
CyclicBarrier | ✓ | ✓ | 支持回调(barrierAction) | 多阶段任务同步 |
CountDownLatch | ✗ | ✓ | 一次性 | 主线程等待多个子线程完成 |
Phaser | ✓ | ✓ | 动态注册/注销 | 复杂分阶段任务 |
Exchanger | ✓ | ✓ | 数据交换 | 线程间数据传递 |
2. 屏障参数配置对比
配置项 | CyclicBarrier | CountDownLatch |
初始化参数 | 等待线程数 | 需要countDown的次数 |
重用方式 | 自动重置 | 需重新创建实例 |
异常处理 | BrokenBarrierException | 无特殊异常 |
五、高级应用技巧
1. 多阶段任务控制
// 使用多个屏障实现多阶段同步
CyclicBarrier phase1 = new CyclicBarrier(3);
CyclicBarrier phase2 = new CyclicBarrier(3, ()->System.out.println("阶段2完成"));// 线程中按顺序等待
phase1.await();
// 执行阶段1任务...
phase2.await();
2. 动态线程管理
// 使用Phaser替代(JDK7+)
Phaser phaser = new Phaser(1); // 注册主线程
for (int i = 0; i < 3; i++) {phaser.register(); // 动态注册任务线程new Thread(() -> {doWork();phaser.arriveAndDeregister(); // 完成任务后注销}).start();
}
phaser.arriveAndAwaitAdvance(); // 主线程等待
3. 性能监控
// 监控屏障等待情况
System.out.println("当前等待线程数: " + barrier.getNumberWaiting());
if (barrier.isBroken()) {System.out.println("警告:屏障已被破坏!");
}
六、工程实践中的陷阱与解决方案
1. 死锁风险场景
// 错误示例:线程池大小 < 屏障要求的parties数
ExecutorService pool = Executors.newFixedThreadPool(2);
CyclicBarrier barrier = new CyclicBarrier(3); // 要求3个线程
pool.submit(() -> barrier.await()); // 永远阻塞
pool.submit(() -> barrier.await());
解决方案:
- 确保线程池大小 ≥ parties数
- 添加超时机制:
barrier.await(10, TimeUnit.SECONDS);
2. 屏障断裂处理
当某个等待线程被中断或超时,会触发BrokenBarrierException
,此时需要:
try {barrier.await();
} catch (BrokenBarrierException e) {// 1. 记录断裂原因// 2. 重置屏障或终止任务barrier.reset(); // 仅CyclicBarrier有效
}
七、性能优化技巧
1. 分层屏障设计
┌─────────────┐ ┌─────────────┐ ┌─────────────┐
│ 子任务组1 │ │ 子任务组2 │ │ 子任务组N │
│ (屏障A) │ │ (屏障A) │ │ (屏障A) │
└──────┬──────┘ └──────┬──────┘ └──────┬──────┘│ │ │└─────────┬────────┴────────┬─────────┘│ 全局屏障B │▼ ▼┌───────────────────┐│ 最终聚合处理 │└───────────────────┘
适用场景:大数据分片处理(如MapReduce)
2. 与ForkJoinPool结合
ForkJoinPool pool = new ForkJoinPool(4);
CyclicBarrier barrier = new CyclicBarrier(4);pool.execute(() -> {// 分治任务1barrier.await();// 合并结果...
});
八、分布式屏障扩展(ZooKeeper实现)
1. 核心原理
┌─────────────┐ ┌─────────────┐
│ 节点1 │ │ 节点2 │
│ 创建临时节点 │───>│ 监听节点变化 │
└─────────────┘ └─────────────┘│ ▲└───────┬───────┘▼┌─────────────┐│ ZooKeeper ││ /barrier │└─────────────┘
2. Java代码片段
public class DistributedBarrier {private final ZooKeeper zk;private final String barrierPath;public void await() throws Exception {zk.create(barrierPath + "/node", null, ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL_SEQUENTIAL);while (true) {List<String> nodes = zk.getChildren(barrierPath, false);if (nodes.size() >= REQUIRED_NODES) {break; // 所有节点就绪}Thread.sleep(100);}}
}
九、监控与调试方案
1. 关键监控指标
指标 | 采集方式 | 健康阈值 |
平均等待时间 | Barrier日志打点 + Prometheus | < 任务超时时间的20% |
屏障断裂次数 | 异常捕获统计 | 每小时 < 3次 |
线程阻塞比例 | ThreadMXBean监控 | < 线程数的30% |
2. Arthas诊断命令
# 查看屏障状态
watch java.util.concurrent.CyclicBarrier getParties returnObj
# 监控等待线程
thread -b | grep 'await'
十、与其他模式的组合应用
1. 屏障 + 生产者消费者模式
┌─────────────┐ ┌─────────────┐ ┌─────────────┐
│ 生产者线程 │ │ 生产者线程 │ │ 屏障 │
│ 生产数据 │───>│ 提交到队列 │───>│ 等待所有生产 │
└─────────────┘ └─────────────┘ └──────┬──────┘│
┌─────────────┐ ┌─────────────┐ ┌──────▼──────┐
│ 消费者线程 │ │ 消费者线程 │ │ 屏障释放 │
│ 开始消费 │<───│ 从队列获取 │<───│ 触发消费信号│
└─────────────┘ └─────────────┘ └─────────────┘
2. 代码示例
BlockingQueue<Data> queue = new LinkedBlockingQueue<>();
CyclicBarrier producerBarrier = new CyclicBarrier(3, () -> {System.out.println("所有生产者完成,启动消费者");startConsumers();
});// 生产者线程
void produce() {queue.put(generateData());producerBarrier.await();
}
相关文章:
并发设计模式实战系列(16):屏障(Barrier)
🌟 大家好,我是摘星! 🌟 今天为大家带来的是并发设计模式实战系列,第十六章屏障(Barrier),废话不多说直接开始~ 目录 一、核心原理深度拆解 1. 屏障的同步机制 2. 关键参数 二…...
pywinauto通过图片定位怎么更加精准的识别图片?
pywinauto通过图片定位怎么更加精准的识别图片? 可以使用置信度的配置,添加了对比图片相似程度达到多少就可以认为是合适的定位图片 import time from time import sleep from pywinauto.application import Application from pywinauto.keyboard impo…...
Spring Cloud Stream集成RocketMQ(kafka/rabbitMQ通用)
什么是Spring Cloud Stream Spring Cloud Stream 是 Spring 生态系统中的一个框架,用于简化构建消息驱动微服务的开发和集成。它通过抽象化的方式将消息中间件(如 RabbitMQ、Kafka、RocketMQ 等)的复杂通信逻辑封装成简单的编程模型…...
基于docker使用showdoc搭建API开发文档服务器
以下是基于 Docker 快速搭建 ShowDoc API 文档服务器的完整指南,包含优化配置和常见问题解决方案: 1. 快速部署方案 # 创建数据目录(确保权限) mkdir -p /showdoc_data/html && chmod 777 -R /showdoc_data# 一键启动容器…...
Vision-Language Models (VLMs) 视觉语言模型的技术背景、应用场景和商业前景(Grok3 DeepSearch模式回答)
prompt: 你是一位文笔精湛、十分专业的技术博客作者,你将从技术背景、应用场景和商业前景等多个维度去向读者介绍Vision-Language Models 关键要点 研究表明,视觉语言模型(VLMs)是多模态AI系统,能同时处理视觉和文本数…...
OpenAI大变革!继续与微软等,以非营利模式冲击AGI
今天凌晨2点,OpenAI宣布,将继续由非营利组织控制;现有的营利性实体将转变为一家公共利益公司;非营利组织将控制该公共利益公司,并成为其重要的持股方。 这也就是说OpenAI曾在去年提到的由非营利性转变成营利性公司&am…...
Ubuntu打开中文文本乱码
文章目录 中文乱码问题修复乱码系统字符编码修改文本编码修改vim乱码 utf-8编码原理特点应用场景与其他编码的转换 iso-8859-1基本信息字符涵盖应用场景与其他编码的关系 ubuntu打开文本出现乱码,可能是编码没设置对。 中文乱码问题 使用vim打开文本,或…...
车载通信网络安全:挑战与解决方案
1. 简介 当今时代见证了车载汽车技术的巨大发展,因为现代智能汽车可以被视为具有出色外部基础设施连接能力的信息物理系统 [ 1 ]。车载技术支持的现代智能汽车不应被视为类似于机械系统,而是由数百万行复杂代码组成的集成架构,可为车内乘客提…...
【Linux系统】读写锁
读者写者问题 重点 读者写者问题是并发编程中的经典问题,主要研究多个进程或线程对共享数据进行读和写操作时如何实现同步和互斥,以保证数据的一致性和操作的正确性 。 问题核心要点 同步与互斥:需要确保多个读者可以同时读共享数据&#…...
springBoot中自定义一个validation注解,实现指定枚举值校验
缘由 在后台写接口的时候,经常会出现dto某个属性是映射到一个枚举的情况。有时候还会出现只能映射到枚举类中部分枚举值的情况。以前都是在service里面自行判断,很多地方代码冗余,所以就想着弄一个自定义的validation注解来实现。 例如下面某…...
【Python】--装饰器
装饰器(Decorator)本质上是一个返回函数的函数 主要作用是:在不修改原函数代码的前提下,给函数增加额外的功能 比如:增加业务,日志记录、权限验证、执行时间统计、缓存等场景 my_decorator def func():pas…...
排序算法——堆排序
一、介绍 「堆排序heapsort」是一种基于堆数据结构实现的高效排序算法。我们可以利用已经学过的“建堆操作”和“元素出堆操作”实现堆排序。 1. 输入数组并建立小顶堆,此时最小元素位于堆顶。 2. 不断执行出堆操作,依次记录出堆元素,即可得…...
Day111 | 灵神 | 二叉树 | 验证二叉搜索树
Day111 | 灵神 | 二叉树 | 验证二叉搜索树 98.验证二叉搜索树 98. 验证二叉搜索树 - 力扣(LeetCode) 方法一:前序遍历 递归函数传入合法的左右边界,只有当前结点是合法的边界,才是二叉搜索树,否则就返回…...
软考-软件设计师中级备考 13、刷题 数据结构
倒计时17天时间不多了,数据库、UML、等知识点有基础直接略过,法律全靠考前的一两天刷题,英语直接放弃。 一、数据结构:链表、栈、队列、数组、哈希表、树、图 1、关于链表操作,说法正确的是: A)新增一个头…...
【5G通信】天线调整
在天线工程中,机械下倾角、电子下倾角和数字下倾角是调整天线波束指向的不同技术手段,其核心区别在于实现方式和灵活性: 1. 机械下倾角(Mechanical Downtilt) 定义:通过物理调整天线的安装角度,…...
Kafka的Log Compaction原理是什么?
Kafka的Log Compaction(日志压缩)是一种独特的数据保留策略,其核心原理是保留每个key的最新有效记录。以下是关键原理分点说明: 1. 键值保留机制 通过扫描所有消息的key,仅保留每个key对应的最新value值。例如&#…...
嵌入式面试八股文(十四)·内存管理机制、优先级继承机制以及优先级翻转
目录 1. 内存管理算法(五种内存管理机制) 1.1 heap_1.c 1.2 heap_2.c 1.3 heap_3.c 1.4 heap_4.c 1.5 heap_5.c 1.6 总结 2. STM32通知寄存器有哪些? 2.1 核心寄存器组(Cortex-M) 2.2 特殊功能寄存…...
深度剖析:可视化如何重塑驾驶舱信息交互模式
为什么你开车时总觉得“信息太多却抓不住重点”? 今天的汽车早已不是单纯的交通工具,而是一个高度集成的信息终端。从导航、油耗、胎压到自动驾驶提示,各种数据不断涌进驾驶舱。 但问题也随之而来: 关键信息被淹没在一堆图标里…...
app根据蓝牙名字不同,匹配不同的产品型号,显示对应的UI界面
在开发一个 App 时,如果希望根据蓝牙设备名称(Bluetooth Name)的不同,自动匹配不同的产品型号,并显示对应的 UI 界面,可以按照以下思路来实现: ✅ 功能目标 扫描并连接蓝牙设备;获取…...
数据结构 --- 栈
1.栈的初始化 2.入栈 3.出栈 4.取出栈顶元素 5.获取栈中有效元素个数 6.栈的销毁 栈:⼀种特殊的线性表,其只允许在固定的⼀端进⾏插⼊和删除元素操作。进⾏数据插⼊和删除操作 的⼀端称为栈顶,另⼀端称为栈底。栈中的数据元素遵守后进先…...
37-算法打卡-栈与队列-滑动窗口最大值-leetcode(239)-第三十七天
1 题目地址 239. 滑动窗口最大值 - 力扣(LeetCode)239. 滑动窗口最大值 - 给你一个整数数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。返回 滑…...
【原创分享】魔音变声器内含超多语音包实时变声
魔音变声器,一款专业的调音变声器软件 亲测可使用所有功能[真棒] 去除所有广告 ————————————【下 载 地 址】———————————— 【获取方法1】:https://pan.xunlei.com/s/VOP_TXtKNlevTgYvIlxmmJquA1?pwd8vpi# ————————————【下 …...
数据结构(一)——线性表的顺序表示和实现
一、线性表的定义 由n(n>0)个数据特性相同的元素构成的有限序列称为线性表,(n0)的时候被称为空表。 一个数据元素可以是简单的一个数据,一个符号,也可以是复杂的若干个数据项的组合。 二、线性表的类型定义 s线性表是由n(n≥0)个相同类…...
Winform(12.控件讲解)
ChildForm窗口: ChildForm代码: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; namespac…...
Python 10天冲刺 《元编程(Meta-programming)》
Python 的元编程(Meta-programming)是指在程序运行期间动态生成、修改或操作代码的技术。它允许开发者通过代码控制代码的行为,从而实现灵活、可扩展和抽象化的编程模式。Python 提供了多种元编程工具,包括装饰器、元类、动态导入…...
Android开发-创建、运行、调试App工程
在移动应用开发的世界里,Android平台凭借其开放性和广泛的设备支持,成为了许多开发者的选择。而要成为一名合格的Android开发者,掌握如何创建、运行以及调试应用程序是必不可少的基础技能。本文将详细介绍如何使用Android Studio完成这些任务…...
系统级编程(二):通过读取PE文件获取EXE或者DLL的依赖
PE文件 Windows的PE文件(Portable Executable)是一种专为Windows操作系统设计的标准可执行文件格式,用于存储和管理可执行程序、动态链接库(DLL)、驱动程序等二进制文件。PE文件格式自Windows NT 3.1引入以来,已成为Windows平台上所有可执行文件的标准格式,并广泛应用于…...
Linux主机时间设置操作指南及时间异常影响
一、Linux主机时间设置命令操作指南 1. 查看当前系统时间与时区 查看当前时间与时区:timedatectl # 显示详细时间与时区信息(systemd系统适用) date # 查看当前系统时间 hwclock --show # 查看硬件时…...
GPS定位方案
目录 一、常用的GPS定位方案包括: 二、主流品牌及热销型号 三、常用GPS算法及核心逻辑: 一、基础定位算法 二、高精度算法 三、辅助优化算法 四、信号处理底层算法 四、基本原理(想自己写算法的琢磨一下原理) 一、常用的GP…...
应对联网汽车带来的网络安全挑战
数字化加速正在彻底改变全球各行各业,而汽车行业更是走在了前列。目前,全球自动驾驶汽车保有量约为4860万辆,预计到2024年将增长至5420万辆。 智能汽车的崛起无疑令人兴奋,但也带来了一系列问题。为了保护客户免受新的威胁,汽车行业必须做出一系列考量:针对自动驾驶、网…...
人工智能与生命科学的深度融合:破解生物医学难题,引领未来科技革命
引言 随着人工智能技术的飞速发展,生命科学领域迎来了前所未有的变革。从药物研发到疾病预测,从个性化医疗到基因组学,AI的深度融入不仅加速了生物医学的进步,还在多个领域打破了传统科学研究的局限,开创了新的医学前沿…...
DeepSeek智能时空数据分析(七):4326和3857两种坐标系有什么区别?各自用途是什么?
序言:时空数据分析很有用,但是GIS/时空数据库技术门槛太高 时空数据分析在优化业务运营中至关重要,然而,三大挑战仍制约其发展:技术门槛高,需融合GIS理论、SQL开发与时空数据库等多领域知识;空…...
Qt/C++面试【速通笔记七】—Qt中为什么new QWidget不需要手动调用delete?
在Qt的开发中,管理内存是一个非常重要的话题,特别是在使用QWidget这类窗口组件时,很多开发者会遇到一个问题:“为什么我使用new QWidget创建的窗口对象不需要手动调用delete进行销毁?”。 1. 父子关系机制:…...
Super-vlan
Super VLAN(VLAN聚合)的理论与配置 1. 基本概念 Super VLAN(超级VLAN)是一种VLAN聚合技术,主要用于解决传统VLAN划分中IP地址浪费的问题。其核心思想是将多个Sub VLAN(子VLAN)聚合到一个Super …...
C——函数
一、函数的概念 数学中我们其实就⻅过函数的概念,⽐如:⼀次函数 y kx b ,k和b都是常数,给⼀个任意的 x,就得到⼀个y值。 其实在C语⾔也引⼊函数(function)的概念,有些翻译为&…...
5.6刷题并查集
P1551 亲戚 #include<bits/stdc.h> using namespace std; const int N 5010; int f[N]; int find(int x){if(f[x] x)return x;return f[x] find(f[x]); } void solve(){int n, m, p; cin >> n >> m >> p;for(int i 1; i < n; i)f[i] i;for(in…...
pcl平面投影
// 创建一个系数为XY0,Z1的平面pcl::ModelCoefficients::Ptr coefficients (new pcl::ModelCoefficients ());coefficients->values.resize (4);coefficients->values[0] coefficients->values[1] 0;coefficients->values[2] 1.0;coefficients->values[3] 0…...
Linux远程管理
如何查看ip 如何使用vim编辑器 如何设置网络信息 远程访问 一:网络管理 (1)获取计算机的网络信息 基本语法: windows ipconfig ifconfig enS33: f1agS4163<UP,BR0ADCAST,RUNNING,MULTICAST> mtu 1500 inet…...
如何添加或删除极狐GitLab 项目成员?
极狐GitLab 是 GitLab 在中国的发行版,关于中文参考文档和资料有: 极狐GitLab 中文文档极狐GitLab 中文论坛极狐GitLab 官网 项目成员 (BASIC ALL) 成员是有权访问您的项目的用户和群组。 每个成员都有一个角色,这决定了他们在项目中可以…...
2025年服务器技术全景解析:量子计算、液冷革命与未来生态构建
2025年服务器技术全景解析:量子计算、液冷革命与未来生态构建 一、量子计算:从实验室到产业化的跨越 1. 中国量子计算产业化突破 • 本源量子“悟空”超导计算机: 搭载72位自主超导量子芯片“悟空芯”,支持198个量子比特…...
Vue3+ Vite + Element-Plus + TypeScript 从0到1搭建
一环境准备 二vite 项目初始化 按照 🍃Vite 官方文档 - 搭建第一个 Vite 项目 说明,执行以下命令完成 vue 、typescirpt 模板项目的初始化 npm init vitelatest vue3-element-admin --template vue-tsvue3-element-admin: 自定义的项目名称 vue-ts &am…...
如何对 Redis 进行水平扩展和垂直扩展以应对微服务流量的增长?
核心概念: 垂直扩展 (Scale Up): 提升单个节点的性能。简单来说就是给现有的 Redis 服务器增加更多的 CPU 、内存、更快的存储(SSD)或更高的网络带宽。水平扩展 (Scale Out): 增加更多节点来分担负载。这意味着部署多个 Redis 实例ÿ…...
PyCharm 加载不了 conda 虚拟环境,不存在的
#工作记录 前言 在开发过程中,PyCharm 无法加载 Conda 虚拟环境是常见问题。 在不同情况下,“Conda 可执行文件路径”的指定可能会发生变化,不会一尘不变,需要灵活处置。 以下是一系列解决此问题的经验参考。 检查 Conda 安装…...
Matlab/Simulink的一些功能用法笔记(4)
水一篇帖子 01--MATLAB工作区的保护眼睛颜色设置 默认的工作区颜色为白色 在网上可以搜索一些保护眼睛的RGB颜色参数设置 在MATLAB中按如下设置: ①点击预设 ②点击颜色,点击背景色的三角标符号 ③点击更多颜色,找到RGB选项 ④填写颜色参数…...
OS7.【Linux】基本指令入门(6)
目录 1.zip和unzip 配置指令 使用 两个名词:打包和压缩 打包 压缩 Linux下的操作演示 压缩和解压缩文件 压缩和解压缩目录 -d选项 2.tar Linux下的打包和压缩方案简介 czf选项 xzf选项 -C选项 tzf选项 3.bc 4.uname 不带选项的uname -a选项 -r选项 -v选项…...
便捷OCR文字识别软件推荐
软件介绍 此次要介绍的是一款OCR识别软件。 核心功能及特点 这款小巧的OCR识别软件,功能简洁,操作方便,只需进行截图,随后就能自动识别文字内容。并且,它具备离线使用的特性,这一特点使得它非常适合在不联…...
【中间件】brpc_基础_栈管理
文章目录 BRPC bthread栈管理1 简介2 关键数据结构2.1 栈描述符 (bthread_stack_t)2.2 栈池 (StackPool) 3 核心操作3.1 栈分配 (bthread_stack_alloc)3.2 栈释放 (bthread_stack_dealloc)3.3 栈切换支持 4 性能优化5 安全性设计6 跨平台实现6.1 Linux6.2 Windows 7 应用场景8 …...
Linux 硬盘和光驱系统管理
一、硬盘与目录的容量 [rootwww ~]# df [-ahikHTm] [目录或档名] 选项与参数: -a :列出所有的档案系统,包括系统特有的 /proc 等档案系统; -k :以 KBytes 的容量显示各档案系统; -m :以 MByt…...
分库分表后复杂查询的应对之道:基于DTS实时性ES宽表构建技术实践
1 问题域 业务发展的初期,我们的数据库架构往往是单库单表,外加读写分离来快速的支撑业务,随着用户量和订单量的增加,数据库的计算和存储往往会成为我们系统的瓶颈,业界的实践多数采用分而治之的思想:分库…...
[三分钟]性能测试工具JMeter入门: 下载安装JMeter并设置中文;JMeter基本使用流程
文章目录 1.下载并打开JMeter2.设置JMeter中文3.JMeter基本使用流程 Apache JMeter 是 Apache 组织基于 Java 开发的压力测试工具。 JMeter 支持多种协议和技术,如 HTTP、HTTPS、FTP、JDBC、SOAP、REST、JMS 等。它不仅可以用于性能测试,还可以用于功能测…...