C# 异步详解
C# 异步编程详解
一、异步编程基础概念
1. 同步 vs 异步
- 同步(Synchronous):任务按顺序执行,前一个任务完成后才会执行下一个
- 异步(Asynchronous):任务可以非阻塞地启动,主线程可以继续执行其他操作
2. 异步编程的优势
- 提高应用程序响应能力(特别是UI应用)
- 更好地利用系统资源
- 避免线程阻塞
- 提高吞吐量
二、C#异步编程模型
1. async/await关键字
public async Task<string> GetDataAsync()
{// 模拟耗时操作await Task.Delay(1000);return "Data loaded";
}// 使用
var data = await GetDataAsync();
Console.WriteLine(data);
关键点:
async
修饰方法,表示该方法包含异步操作await
关键字用于等待异步操作完成- 异步方法返回
Task
或Task<T>
2. Task和Task
// 返回void的异步方法(仅用于事件处理)
public async void HandleButtonClick()
{await SomeAsyncOperation();
}// 返回Task的异步方法
public async Task ProcessDataAsync()
{await File.ReadAllTextAsync("data.txt");
}// 返回Task<T>的异步方法
public async Task<int> CalculateSumAsync(IEnumerable<int> numbers)
{return await Task.Run(() => numbers.Sum());
}
Task状态:
Created
:已创建但未启动WaitingForActivation
:等待激活WaitingToRun
:等待运行Running
:正在运行RanToCompletion
:已完成Canceled
:已取消Faulted
:出错
三、异步方法实现方式
1. 基于I/O的异步操作
// 文件I/O
public async Task ReadFileAsync(string path)
{using (var reader = File.OpenText(path)){var content = await reader.ReadToEndAsync();Console.WriteLine(content);}
}// 网络I/O
public async Task DownloadDataAsync(string url)
{using (var client = new HttpClient()){var response = await client.GetStringAsync(url);Console.WriteLine(response);}
}
2. 基于CPU的异步操作
// 使用Task.Run将CPU密集型工作转移到线程池
public async Task ProcessDataAsync(IEnumerable<int> data)
{var result = await Task.Run(() =>{// CPU密集型计算return data.Sum(x => x * x);});Console.WriteLine($"Sum: {result}");
}
注意:对于真正的并行计算,考虑使用Parallel.For
或PLINQ
3. 组合多个异步操作
// 等待多个任务完成
public async Task ProcessMultipleAsync()
{var task1 = GetDataAsync();var task2 = GetOtherDataAsync();// 等待所有完成await Task.WhenAll(task1, task2);Console.WriteLine($"Data1: {task1.Result}, Data2: {task2.Result}");
}// 等待任意一个完成
public async Task ProcessAnyAsync()
{var task1 = GetDataAsync();var task2 = GetOtherDataAsync();var completedTask = await Task.WhenAny(task1, task2);Console.WriteLine($"Completed: {completedTask == task1 ? "Task1" : "Task2"}");
}
四、异步编程最佳实践
1. 避免async void
// 不推荐 - 无法捕获异常
public async void DangerousMethod()
{throw new Exception("Oops!");
}// 推荐 - 可以await或等待
public async Task SafeMethodAsync()
{await Task.Delay(100);throw new Exception("Oops!");
}
例外:事件处理程序可以使用async void
2. 异常处理
public async Task HandleExceptionsAsync()
{try{await SomeAsyncOperation();}catch (Exception ex){// 处理异常Console.WriteLine($"Error: {ex.Message}");}
}// 多个任务的异常处理
public async Task HandleMultipleExceptionsAsync()
{try{await Task.WhenAll(Operation1(),Operation2(),Operation3());}catch (AggregateException ae){foreach (var ex in ae.InnerExceptions){Console.WriteLine($"Error: {ex.Message}");}}
}
3. 取消异步操作
// 使用CancellationToken
public async Task LongRunningOperationAsync(CancellationToken token)
{for (int i = 0; i < 100; i++){token.ThrowIfCancellationRequested();await Task.Delay(100, token);Console.WriteLine($"Step {i}");}
}// 使用示例
var cts = new CancellationTokenSource();
try
{await LongRunningOperationAsync(cts.Token);
}
catch (OperationCanceledException)
{Console.WriteLine("Operation was canceled");
}// 取消操作
cts.Cancel();
4. 异步方法设计原则
- 返回Task而非void(除非是事件处理程序)
- 避免在异步方法中使用Result或Wait()(可能导致死锁)
- 保持异步方法链(避免混合同步和异步代码)
- 考虑异步方法的粒度(不要过度拆分)
五、异步与并行编程
1. 异步 vs 并行
特性 | 异步编程 | 并行编程 |
---|---|---|
目标 | 非阻塞执行 | 同时执行多个任务 |
线程使用 | 通常不创建新线程 | 使用多个线程 |
适用场景 | I/O密集型操作 | CPU密集型操作 |
关键字 | async/await | Parallel.For/ForEach |
2. 混合使用示例
public async Task ProcessDataAsync(IEnumerable<Data> data)
{// 并行处理数据项var processedData = data.AsParallel().Select(d => ProcessItem(d)).ToList();// 异步保存结果await SaveResultsAsync(processedData);
}private Data ProcessItem(Data d)
{// CPU密集型处理return new Data { /* ... */ };
}private async Task SaveResultsAsync(IEnumerable<Data> data)
{// 异步保存到数据库await _dbContext.BulkInsertAsync(data);
}
六、异步编程中的常见问题
1. 死锁问题
错误示例:
public async Task DeadlockExample()
{await Task.Run(async () =>{// 在UI线程上调用Wait()会导致死锁await SomeAsyncOperation().ConfigureAwait(false); // 解决方案}).Wait(); // 阻塞调用
}
解决方案:
- 使用
ConfigureAwait(false)
(非UI上下文) - 避免在异步方法中调用
.Result
或.Wait()
- 使用
await
而不是Task.Run
包装异步操作
2. 上下文保留问题
// 默认情况下,await会捕获当前上下文(如UI线程)
public async Task UpdateUIAsync()
{var data = await GetDataAsync();// 自动回到UI线程textBox.Text = data;
}// 如果不需要回到原始上下文
public async Task ProcessInBackgroundAsync()
{var data = await GetDataAsync().ConfigureAwait(false);// 不会回到原始上下文ProcessData(data);
}
3. 性能优化
避免过度异步化:
// 不必要的异步包装
public async Task UnnecessaryAsync()
{await Task.Run(() => {// 同步操作Thread.Sleep(1000);});
}
正确做法:
- 只对真正的I/O操作使用异步
- 对CPU密集型操作考虑并行处理
- 避免在热路径上使用异步(如游戏循环)
七、高级异步模式
1. 异步流(IAsyncEnumerable)
// 生成异步流
public async IAsyncEnumerable<int> GenerateNumbersAsync(int count)
{for (int i = 0; i < count; i++){await Task.Delay(100); // 模拟异步操作yield return i;}
}// 使用异步流
await foreach (var number in GenerateNumbersAsync(10))
{Console.WriteLine(number);
}
2. 异步锁
private readonly SemaphoreSlim _semaphore = new(1, 1);public async Task ProtectedOperationAsync()
{await _semaphore.WaitAsync();try{// 受保护的代码}finally{_semaphore.Release();}
}
3. 异步工厂模式
public interface IAsyncFactory<T>
{Task<T> CreateAsync();
}public class AsyncDataFactory : IAsyncFactory<Data>
{public async Task<Data> CreateAsync(){await Task.Delay(100); // 模拟异步初始化return new Data();}
}
八、异步测试
1. 单元测试异步方法
[Fact]
public async Task TestAsyncMethod()
{// Arrangevar service = new MyService();// Actvar result = await service.GetAsync();// AssertAssert.NotNull(result);
}// 使用Moq测试异步方法
[Fact]
public async Task TestWithMock()
{var mock = new Mock<IRepository>();mock.Setup(r => r.GetDataAsync()).ReturnsAsync(new Data { Id = 1 });var service = new MyService(mock.Object);var result = await service.GetData();Assert.Equal(1, result.Id);
}
2. 测试异步代码中的异常
[Fact]
public async Task TestException()
{// Arrangevar service = new FaultyService();// Act & Assertawait Assert.ThrowsAsync<InvalidOperationException>(() => service.FaultyOperationAsync());
}
九、异步性能监控
1. 使用DiagnosticSource
// 在异步方法中添加诊断事件
private static readonly DiagnosticSource _diagnosticSource = new DiagnosticListener("MyAsyncComponent");public async Task ProcessAsync()
{if (_diagnosticSource.IsEnabled("StartProcess")){_diagnosticSource.Write("StartProcess", new { Timestamp = DateTime.UtcNow });}await Task.Delay(100);if (_diagnosticSource.IsEnabled("EndProcess")){_diagnosticSource.Write("EndProcess", new { Duration = 100 });}
}
2. 使用AsyncLocal跟踪上下文
private static readonly AsyncLocal<string> _context = new();public async Task OperationWithContext()
{_context.Value = "OperationStarted";await Task.Delay(100);Console.WriteLine(_context.Value); // 仍然可以访问
}
十、异步编程的未来发展
1. C#中的新特性
- C# 8.0:IAsyncEnumerable
- C# 9.0:异步流改进
- C# 10.0:更高效的异步方法生成
2. .NET中的改进
- .NET Core 3.0+:更好的异步IO性能
- .NET 5+:统一的异步API
- .NET 6+:更智能的异步调度器
十一、最佳实践总结
- 优先使用async/await而非ContinueWith或Task.Result
- 在UI应用中,确保异步操作回到UI线程(使用ConfigureAwait(false)谨慎)
- 避免混合同步和异步代码(如Wait()和Result)
- 为长时间运行的操作使用CancellationToken
- 考虑异步流处理连续数据(如日志、传感器数据)
- 测试异步代码时使用AsyncTestMethods
- 监控异步性能以识别瓶颈
- 保持异步方法链避免混合同步/异步调用
相关文章:
C# 异步详解
C# 异步编程详解 一、异步编程基础概念 1. 同步 vs 异步 同步(Synchronous):任务按顺序执行,前一个任务完成后才会执行下一个异步(Asynchronous):任务可以非阻塞地启动,主线程可以继续执行其他操作 2. 异步编…...
X²+1素数问题
X1素数问题是与哥德巴赫猜想和孪生素数猜想同时代的著名数学难题。是否有无穷个正整数x,使得x1总是素数? 其困难程度不亚于哥德巴赫猜想。特别是100多年以来,许许多多一流数论学者对这个问题进行了研究。 X1素数 X1素数是一个著名的猜想&…...
【自定义控件实现最大高度和最大宽度实现】
背景 开发中偶尔遇到控件宽度或者高度在自适应的情况下,有个边界值,也就是最大值。 比如高度自适应的情况下最大高度300dp这种场景。 实现 关键节点代码: Overrideprotected void onMeasure(int widthMeasureSpec, int heightMeasureSpec)…...
基于C++的IOT网关和平台4:github项目ctGateway交互协议
初级代码游戏的专栏介绍与文章目录-CSDN博客 我的github:codetoys,所有代码都将会位于ctfc库中。已经放入库中我会指出在库中的位置。 这些代码大部分以Linux为目标但部分代码是纯C++的,可以在任何平台上使用。 源码指引:github源码指引_初级代码游戏的博客-CSDN博客 …...
DeepSeek谈《凤凰项目 一个IT运维的传奇故事》
《凤凰项目:一个IT运维的传奇故事》(The Phoenix Project: A Novel About IT, DevOps, and Helping Your Business Win)是Gene Kim、Kevin Behr和George Spafford合著的一部小说,通过虚构的故事生动展现了IT运维中的核心挑战和Dev…...
Spyglass:官方Hands-on Training(一)
相关阅读 Spyglasshttps://blog.csdn.net/weixin_45791458/category_12828934.html?spm1001.2014.3001.5482 本文是对Spyglass Hands-on Training中第一个实验的翻译(有删改),Lab文件可以从以下链接获取。Spyglass Hands-on Traininghttps:…...
10.idea中创建springboot项目_jdk17
10.idea中创建springboot项目_jdk17 1. 准备工作 安装 JDK 17: 确保已安装 JDK 17,并配置环境变量 JAVA_HOME 指向 JDK 17 的安装路径。在 IntelliJ IDEA 中验证 JDK 配置:File → Project Structure → SDKs。 安装 IntelliJ IDEA&#x…...
指令级并行(ILP)和线程级并行(TLP)的区别,GCC -O3优化会展开循环吗?
1. GCC 自动循环展开是怎么展开的? 当你使用 -O3 这样的优化选项时,GCC 会分析你的循环。如果它认为展开循环有利可图,它会做类似这样的事情(概念上的): 原始循环 (Conceptual C Code): for (int i 0; i …...
hadoop伪分布式模式
以下是 Hadoop 伪分布式模式(Pseudo-Distributed Mode)的环境搭建步骤。伪分布式模式下,Hadoop 的各个组件(如 HDFS、YARN、MapReduce)以独立进程运行,但所有服务均部署在单台机器上,模拟多节点…...
C++入门小馆: 模板
嘿,各位技术潮人!好久不见甚是想念。生活就像一场奇妙冒险,而编程就是那把超酷的万能钥匙。此刻,阳光洒在键盘上,灵感在指尖跳跃,让我们抛开一切束缚,给平淡日子加点料,注入满满的pa…...
# 基于 Python 和 jieba 的中文文本自动摘要工具
基于 Python 和 jieba 的中文文本自动摘要工具 在信息爆炸的时代,快速准确地提取文本核心内容变得至关重要。今天,我将介绍一个基于 Python 和 jieba 的中文文本自动摘要工具,帮助你高效地从长文本中提取关键信息。 一、背景与需求 在处理…...
.NET平台用C#在PDF中创建可交互的表单域(Form Field)
在日常办公系统开发中,涉及 PDF 处理相关的开发时,生成可填写的 PDF 表单是一种常见需求,例如员工信息登记表、用户注册表、问卷调查或协议确认页等。与静态 PDF 不同,带有**表单域(Form Field)**的文档支持…...
Azure AI Foundry实战:从零开始构建智能应用
1. 引言 在人工智能快速发展的今天,如何高效地开发和部署AI应用已成为众多开发者和企业关注的焦点。微软的Azure AI Foundry应运而生,为AI应用开发提供了一站式解决方案。本文将带您深入了解Azure AI Foundry,并通过实战指南,帮助您从零开始构建智能应用。 2. Azure AI Found…...
YOLO视觉模型可视化训练与推理测试工具
推荐一款YOLO可视化训练测试工具: 对于yolo的训练,新手小白往往无从下手,本章推荐的这款工具可以非常轻易的帮您从模型训练到测试到部署。 下载地址http://www.voouer.com/yolo 可以点击此处跳转。 下载成功后打开这款工具,将会出现图形化界面,类似于下图所示: 当前页是可视…...
数据清洗的定义跟实际操作
数据清洗的定义 数据清洗(Data Cleaning) 是指对原始数据进行处理,以纠正、删除或填补不完整、不准确、重复或无关的数据,使其符合分析或建模的要求。数据清洗是数据预处理的关键步骤,直接影响后续分析和机器学习模型…...
如何用AI生成个人职业照/西装照?
一、核心工具推荐与对比 1. 搜狐简单AI • 特点: • 一键生成:上传1张生活照,AI自动生成职业照/西装照,支持商务精英、韩系女主等20模板。 • 自然微调:优化五官比例、柔化法令纹,保留个人特色࿰…...
Ecology中拦截jquery.ajax请求接口后的数据
功能:获取调用接口之后的数据在进行返回参数重写 首先ecology中一般直接看不到源码的,为什么知道是jquery.ajax请求呢,需要用到开发者工具 点开这里之后就能知道调用接口具体走的是什么逻辑然后返回值又做了哪些操作 一般来说,文…...
基于站点观测的中国1km土壤湿度日尺度数据集(2000-2022)
A 1 km daily soil moisture dataset over China based on in-situ measurement (2000-2022) 关键数据集分类地表参数数据集时间分辨率日空间分辨率1km - 10km共享方式开放获取数据大小592.76 GB数据时间范围 1999-12-31 — 2022-12-31 元数据更新时间2024-08-09 数据集摘要 …...
Django 自定义celery-beat调度器,查询自定义表的Cron表达式进行任务调度
学习目标: 通过自定义的CronScheduler调度器在兼容标准的调度器的情况下,查询自定义任务表去生成调度任务并分配给celery worker进行执行 不了解Celery框架的小伙伴可以先看一下我的上一篇文章:Celery框架组件分析及使用 学习内容ÿ…...
第 12 届蓝桥杯 C++ 青少组中 / 高级组省赛 2021 年 4 月 24 日真题
一、选择题 第 1 题 单选题 题目:在 C++ 中下列哪个不属于字符型常量 ( )。 A. ‘a’ B. ‘\x2A’ C. ‘@’ D. “F” 答案:D 解析:字符型常量使用单引号括起单个字符(如 A、C),或转义字符(如 B 中的十六进制转义字符)。D 选项 “F” 使用双引号,属于字符串常量,而…...
windows远程服务器数据库的搭建和远程访问(Mysql忘记密码通过Navicat连接记录解密密码)
服务器数据库的搭建和远程访问 mysql数据库安装(详细) window安装mysql详细流程 路程:重设MySQL5密码,发现远程服务器原本有一个MySQL5,尝试在服务器本地建立连接被拒绝,因为不知道密码。 (1…...
w~大模型~合集14
我自己的原文哦~ https://blog.51cto.com/whaosoft/13884560 #Attention as an RNN Bengio等人新作:注意力可被视为RNN,新模型媲美Transformer,但超级省内 , 既能像 Transformer 一样并行训练,推理时内存需求又不随 token 数…...
2025平航杯—团队赛
2025平航杯团队赛 计算机取证 分析起早王的计算机检材,起早王的计算机插入过USB序列号是什么(格式:1)分析起早王的计算机检材,起早王的便签里有几条待干(格式:1)分析起早王的计算机检材,起早王的计算机默认浏览器是什…...
5、SpringBoot整合RabbitMQ
5.1 工作队列模式 1、生产者 引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId></dependency><dependency><groupId>org.springframework.boot</gro…...
深度学习论文: Describe Anything: Detailed Localized Image and Video Captioning
深度学习论文: Describe Anything: Detailed Localized Image and Video Captioning Describe Anything: Detailed Localized Image and Video Captioning PDF: https://arxiv.org/pdf/2504.16072 PyTorch代码: https://github.com/shanglianlm0525/CvPytorch PyTorch代码: htt…...
Seata客户端@GlobalTransactional核心源码解析
文章目录 前言一、GlobalTransactional1.1、wrapIfNecessary1.2、handleGlobalTransaction1.3、invoke 二、总结 前言 Seata是阿里开源的分布式事务解决方案。在Spring传统的事务中,开启事务,执行事务,回滚/提交事务,统一由Spring…...
某大麦某眼手机端-抢票
引言 仅供学习研究,欢迎交流 抢票难,难于上青天!无论是演唱会、话剧还是体育赛事,大麦网的票总是秒光。作为一名技术爱好者,你是否想过用技术手段提高抢票成功率?本文将为你揭秘大麦手机端抢票的核心技术…...
深入探索ChatClient:简化AI模型交互的强大工具
深入探索ChatClient:简化AI模型交互的强大工具 前言 在人工智能飞速发展的当下,大语言模型(LLM)的应用越来越广泛。然而,构建基于LLM的应用程序并非易事,通常需要多个组件协同工作,如提示词模…...
AI 知识库:企业知识管理的利器
在数字化转型的今天,企业每天都会产生海量的信息和数据。从客户资料到内部文档,从市场调研到项目经验,这些宝贵的知识资源构成了企业的核心竞争力。然而,你是否注意到这样一个问题:很多企业在快速发展的同时࿰…...
【STM32实物】基于STM32的RFID多卡识别语音播报系统设计
演示视频: 基于STM32的RFID多卡识别语音播报系统设计 前言:本项目可实现多个电子标签IC卡RFID识别,刷卡识别后进行中文语音播报反馈,同时进行控制对应的灯光开关。以此也可扩展开发更多功能。 本项目所需主要硬件包括:STM32F103C8T6最小系统板、RFID-RC522模块、五个IC电…...
[实战] Petalinux驱动开发以及代码框架解读
目录 Petalinux驱动开发以及代码框架解读一、引言二、步骤2.1 创建PetaLinux工程2.2 配置硬件描述文件2.3 设备树配置2.4 建立驱动框架2.5 编辑 .bb 文件2.6 编写驱动文件2.7 编写 Makefile2.8 验证配方配置2.9 集成驱动到 RootFS2.10 全系统编译与部署2.11 启动验证 三、框架解…...
ArcGIS Pro几个小知识点分享
相信熟悉ArcGIS 10.X系统的朋友接触ArcGIS Pro或者QGIS的上手难度都很低,因此向大家分享我最近才注意到的一些ArcGIS Pro小的知识点或者注意事项等,用来查缺补漏。如果是GIS新手小白,建议先去了解GIS相关理论基础,再摸索GIS相关软…...
运维仙途 第1章 灵机突现探监控
第1章 灵机突现探监控 情节梗概 凌运维本是青云门杂役弟子,负责看守藏经阁灵脉枢纽。某日子夜,护山大阵突然灵力紊乱,阁中古籍无风自动。危急时刻,他意外触发祖师留下的「混沌钟」,获得观测灵脉状态的能力… 技术映…...
深入解析Java架构师面试:从核心技术到AI应用
深入解析Java架构师面试:从核心技术到AI应用 在互联网大厂的Java求职者面试中,技术深度和项目经验是成功的关键。本文以严肃的面试官与资深Java架构师马架构(拥有十年研发及架构设计经验)之间的对话为背景,详细展示了…...
Grounding DINO
论文标题: Grounding DINO: Marrying DINO with Grounded Pre-Training for Open-Set Object Detection 代码地址: GitHub - IDEA-Research/GroundingDINO: [ECCV 2024] Official implementation of the paper "Grounding DINO: Marrying DINO …...
MCP协议:自然语言与结构化数据的双向桥梁 ——基于JSON-RPC 2.0的标准化实践
MCP协议:自然语言与结构化数据的双向桥梁 ——基于JSON-RPC 2.0的标准化实践 一、MCP的本质:标准化共识的协议框架 MCP(Model Context Protocol)是Anthropic于2024年提出的开放通信协议,其核心价值在于建立自然语言…...
区块链+医疗:破解数据共享困局,筑牢隐私安全防线
在医疗健康领域,数据共享与隐私保护一直是一对难以调和的矛盾。一方面,分散在不同机构的医疗数据(如电子病历、检查报告、用药记录)阻碍了诊疗效率和科研进展;另一方面,患者隐私泄露事件频发,加…...
Arduino IDE中更新esp32 3.2.0版本的办法
在Arduino IDE中更新esp32-3.2.0版本是个不可能的任务,下载文件速度极慢。网上提供了离线的办法,提供了安装文件,但是没有3.2.0的版本。 下面提供了一种离线安装方法 一、腾讯元宝查询解决办法 通过打开开发板管理地址:通过在腾…...
关于 live555延迟优化之缓存区优化“StreamParser::afterGettingBytes() warning: read”” 的解决方法
若该文为原创文章,转载请注明原文出处 本文章博客地址:https://hpzwl.blog.csdn.net/article/details/146354088 长沙红胖子Qt(长沙创微智科)博文大全:开发技术集合(包含Qt实用技术、树莓派、三维、OpenCV…...
毫米波通信的技术挑战与解决方案
毫米波通信的技术挑战与解决方案 随着5G技术的迅速发展,毫米波通信(Millimeter Wave, mmWave)作为一种具有巨大潜力的通信技术,正在成为实现超高速数据传输、低延迟和大规模连接的关键。然而,毫米波通信虽然在理论上具…...
软考中级-软件设计师 数据库(手写笔记)
基本概念 数据库分析设计过程 E-R模型 关系模式 关系模式相关名词和完整性约束和关系的三种类型 七种基本算法 并交查和笛卡尔积 投影选择和连接 题 规范化-函数依赖 求候选码 非规范化可能处于的问题 问题 题 关系-模型分解 事务管理 备份和恢复 数据仓库和数据挖掘...
Compose笔记(二十一)--AnimationVisibility
这一节主要了解一下Compose的AnimationVisibility,AnimatedVisibility 是 Jetpack Compose 里用于实现组件可见性动画效果的组件,借助它能让组件在显示和隐藏时带有平滑的过渡动画,从而提升用户体验。现总结如下: API 1. visible 含义:这是一…...
生物化学笔记:神经生物学概论05 感受野 视觉中枢 高级视皮层中的信息走向
信息传递中的“击鼓传花” 新特性的突现 功能柱:简化节点 高级视皮层中的信息走向...
记录idea可以运行但是maven install打包却找不到问题
解决idea使⽤maven多模块install报依赖模块的包找不到的问题 如果被依赖项⽬是springboot项⽬,那么可以把相关的springboot的东西移除掉,改造成普通项⽬。如果不想改造项⽬,那就添加部分的配置,因为springboot项⽬打包的时候会⽣…...
牛客:AB5 点击消除
链接:点击消除_牛客题霸_牛客网 题解: 利用栈,遍历输入的字符串,栈为空则入栈,栈不为空则去除栈顶字符和当前遍历到的字符比较,相等则栈顶字符出栈,当前遍历的字符也不入栈,不相等…...
vue3 动态修改系统title
vue3 动态修改系统title 修改前 修改后 1、封装 useTitle 工具函数 创建组合式 API,通过 watchEffect 监听标题变化: // composables/useTitle.js import { ref, watchEffect } from vue;export function useTitle(initialTitle) {const title r…...
产品经理.产品设计.产品设计工具
一、 产品经理常用工具 1. 业务流程图---系统流程图 业务流程图,面向用户调研,描述业务的流转和数据的处理要求,跟用户和业务方确认;---业务角色的泳道流程图。 系统流程图,面向产品需求设计, prd系描述各…...
kibana重建es索引
kibana如何重命名es索引名 背景 在初期设计es索引文档的时候考虑不是很周全,会多出很多无效字段。如果不删除或禁用对后续数据增量以及文档维护会有不良影响。 技术实现 使用 _reindex 1.执行Reindex # 复制旧索引数据到新索引 POST _reindex {"source&qu…...
windows系统常用快捷键(CMD常用命令,DOS常用命令)
Windows系统常用快捷键 Win E: 打开“文件资源管理器”(我的电脑)。Win S: 打开“搜索”功能,可以搜索文件、应用、设置等。Win I: 打开“设置”菜单,用于调整系统设置。Win X: 打开“快速链接”菜单,包含电源选项…...
使用 ossutil 上传文件到阿里云 OSS
在处理文件存储和传输时,阿里云的对象存储服务(OSS)是一个非常方便的选择。特别是在需要批量上传文件或通过命令行工具进行文件管理时,ossutil提供了强大的功能。本文将详细说明如何使用 ossutil 上传文件到阿里云 OSS,…...