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

软件架构风格系列(4):事件驱动架构

在这里插入图片描述

文章目录

  • 前言
    • 一、从“用户下单”场景看懂事件驱动核心概念
      • (一)什么是事件驱动架构?
      • (二)核心优势:解耦与异步的双重魔法
    • 二、架构设计图:三要素构建事件流转闭环
    • 三、Java实战:从简单事件总线到分布式消息队列
      • (一)基于Spring Event的轻量级实现(单体应用)
        • 1. 定义事件类
        • 2. 事件发布者(订单服务)
        • 3. 事件订阅者(库存服务)
      • (二)分布式场景:基于RabbitMQ的事件驱动(微服务)
        • 1. 添加依赖
        • 2. 配置队列和交换机
        • 3. 生产者发送事件
        • 4. 消费者监听事件
    • 四、适用场景与避坑指南
      • (一)这些场景请优先选择EDA
      • (二)踩坑预警:这3个陷阱别掉进去
    • 五、总结:事件驱动架构的“成人世界法则”

前言

在电商大促的凌晨零点,当千万用户同时下单时,你是否好奇过系统如何在毫秒级内完成库存扣减、支付通知、物流调度等一系列操作?答案往往藏在一种低调却强大的架构风格里——事件驱动架构(EDA)。作为一个见证过多个大流量系统落地的老湿机,今天就来拆解这种架构的核心逻辑,并用Java代码带你从理论走到实战。

一、从“用户下单”场景看懂事件驱动核心概念

(一)什么是事件驱动架构?

简单来说,它是一种“以事件为中心”的设计模式:

  • 事件(Event):系统中发生的“有意义的状态变化”,比如“订单创建”“库存变更”“支付成功”。
  • 发布者(Publisher):产生事件的组件(如订单服务),只负责“说发生了什么”,不关心谁来处理。
  • 订阅者(Subscriber):对特定事件感兴趣的组件(如库存服务、物流服务),只关注“我该做什么”。
  • 事件通道(Event Channel):连接发布者和订阅者的“中介”,可以是内存中的事件总线,也可以是Kafka、RabbitMQ等消息队列。

(二)核心优势:解耦与异步的双重魔法

想象一下传统的“同步调用”:订单服务需要依次调用库存服务扣减库存、支付服务发起扣款、物流服务生成运单,任何一个环节卡顿都会拖慢整个流程。
而事件驱动架构下:

  1. 订单服务只需发布“订单创建事件”到消息队列,无需等待下游响应;
  2. 库存、支付、物流服务各自监听队列,异步处理事件;
  3. 新增功能(如积分系统)只需订阅事件,无需修改原有代码。

这种“发布-订阅”模式让系统像乐高积木一样灵活组装,扛住流量洪峰的同时,还能快速响应业务变化。

二、架构设计图:三要素构建事件流转闭环

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  • 生产者层:业务触发时生成事件,比如用户提交订单后,订单服务生成OrderCreatedEvent
  • 事件通道层:负责事件的可靠传输,支持异步解耦和流量削峰。常见实现包括:
    • 轻量级:Spring ApplicationEvent(适合单体应用)
    • 分布式:Kafka(适合高吞吐量)、RabbitMQ(适合精准投递)
  • 消费者层:监听特定事件并执行业务逻辑,支持横向扩展(如部署多个库存服务实例)。

三、Java实战:从简单事件总线到分布式消息队列

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

(一)基于Spring Event的轻量级实现(单体应用)

1. 定义事件类
@Getter
public class OrderCreatedEvent {private final String orderId;private final List<String> productIds;public OrderCreatedEvent(String orderId, List<String> productIds) {this.orderId = orderId;this.productIds = productIds;}
}
2. 事件发布者(订单服务)
@Service
public class OrderService {private final ApplicationEventPublisher eventPublisher;@Autowiredpublic OrderService(ApplicationEventPublisher eventPublisher) {this.eventPublisher = eventPublisher;}public String createOrder(String orderId, List<String> productIds) {// 业务逻辑:创建订单记录System.out.println("订单 " + orderId + " 创建成功");// 发布事件eventPublisher.publishEvent(new OrderCreatedEvent(orderId, productIds));return orderId;}
}
3. 事件订阅者(库存服务)
@Service
public class InventoryService {@EventListenerpublic void handleOrderCreated(OrderCreatedEvent event) {String orderId = event.getOrderId();List<String> productIds = event.getProductIds();// 业务逻辑:扣减库存System.out.println("订单 " + orderId + " 触发库存扣减,商品ID:" + productIds);// 模拟库存扣减耗时操作try {Thread.sleep(100);} catch (InterruptedException e) {Thread.currentThread().interrupt();}}
}

(二)分布式场景:基于RabbitMQ的事件驱动(微服务)

1. 添加依赖
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
2. 配置队列和交换机
@Configuration
public class RabbitMQConfig {public static final String ORDER_QUEUE = "order_queue";public static final String ORDER_EXCHANGE = "order_exchange";public static final String ORDER_ROUTING_KEY = "order.routing.key";@Beanpublic Queue orderQueue() {// 持久化队列return new Queue(ORDER_QUEUE, true); }@Beanpublic DirectExchange orderExchange() {return new DirectExchange(ORDER_EXCHANGE);}@Beanpublic Binding orderBinding(Queue orderQueue, DirectExchange orderExchange) {return BindingBuilder.bind(orderQueue).to(orderExchange).with(ORDER_ROUTING_KEY);}
}
3. 生产者发送事件
@Service
public class RabbitMQProducer {private final RabbitTemplate rabbitTemplate;@Autowiredpublic RabbitMQProducer(RabbitTemplate rabbitTemplate) {this.rabbitTemplate = rabbitTemplate;}public void sendOrderEvent(OrderCreatedEvent event) {// 将事件序列化为JSON发送到队列rabbitTemplate.convertAndSend(RabbitMQConfig.ORDER_EXCHANGE,RabbitMQConfig.ORDER_ROUTING_KEY,event);}
}
4. 消费者监听事件
@Service
public class RabbitMQConsumer {@RabbitListener(queues = RabbitMQConfig.ORDER_QUEUE)public void receiveOrderEvent(OrderCreatedEvent event) {// 处理逻辑与单体应用类似,支持分布式部署System.out.println("分布式场景接收到事件:" + event.getOrderId());}
}

四、适用场景与避坑指南

(一)这些场景请优先选择EDA

  1. 高并发异步处理:电商下单、秒杀活动,通过事件队列削峰填谷,避免数据库被压垮。
  2. 微服务解耦:不同微服务通过事件通信,服务A无需知道服务B的接口和地址,降低耦合度。
  3. 实时数据处理:金融行情分析、用户行为追踪,事件流处理框架(如Kafka Streams)可实时消费事件并计算。
  4. 最终一致性:分布式事务中,通过事件重试和补偿机制实现最终一致性(如TCC模式结合事件驱动)。

(二)踩坑预警:这3个陷阱别掉进去

  1. 事件膨胀:避免在事件中携带过多数据(如整个订单对象),只传递必要字段(如orderId),减少网络传输开销。
  2. 顺序性问题:对订单支付、退款等有严格顺序的事件,需在事件中添加sequenceId,消费者按顺序处理(可借助Redis实现分布式锁)。
  3. 事件回溯困难:生产环境建议使用可持久化的消息队列,并记录事件日志,方便故障时重放事件恢复状态。

五、总结:事件驱动架构的“成人世界法则”

事件驱动架构的本质,是承认系统的“不完美”:

  • 接受组件可能崩溃,通过事件重试和幂等性设计保证可靠性;
  • 接受需求会变化,通过松耦合让系统像搭积木一样灵活组装;
  • 接受流量会波动,通过异步队列将突发压力转化为可处理的平稳水流。

从单体应用的Spring Event到分布式系统的Kafka,这种架构风格贯穿了从小型工具到亿级流量平台的全生命周期。如果你正在设计一个需要“抗住现在、适配未来”的系统,事件驱动架构绝对是值得深入研究的“秘密武器”。


最后留个小问题:你认为事件驱动架构和微服务架构是如何相辅相成的?欢迎在评论区聊聊你的想法~

图片来源于网络

相关文章:

软件架构风格系列(4):事件驱动架构

文章目录 前言一、从“用户下单”场景看懂事件驱动核心概念&#xff08;一&#xff09;什么是事件驱动架构&#xff1f;&#xff08;二&#xff09;核心优势&#xff1a;解耦与异步的双重魔法 二、架构设计图&#xff1a;三要素构建事件流转闭环三、Java实战&#xff1a;从简单…...

软件架构风格系列(2):面向对象架构

文章目录 引言一、什么是面向对象架构风格1. 定义与核心概念2. 优点与局限性二、业务建模&#xff1a;用对象映射现实世界&#xff08;一&#xff09;核心实体抽象1. 员工体系2. 菜品体系 &#xff08;二&#xff09;封装&#xff1a;隐藏实现细节 三、继承实战&#xff1a;构建…...

python打卡day27

函数装饰器 知识点回顾&#xff1a; 装饰器的思想&#xff1a;进一步复用函数的装饰器写法注意内部函数的返回值 日常ctrl点进某个复杂的项目&#xff0c;发现函数定义上方有一个xxx,它就是装饰器。装饰器本质上是一个 Python 函数&#xff0c;可以在不修改原函数代码的情况下&…...

智能AI构建工地安全网:跌倒、抽搐、区域入侵多场景覆盖

智能AI在工地安全中的应用&#xff1a;从监测到救援的全流程实践 一、背景&#xff1a;高温作业下的工地安全挑战 随着夏季高温持续&#xff0c;工地户外作业环境面临严峻考验。工人因高温疲劳、脱水或突发疾病引发的行为异常&#xff08;如晕厥、抽搐、跌倒&#xff09;频发…...

gflags 安装及使用

目录 引言 安装 如何用 gflags 库写代码 如何用命令行使用 gflags 库 gflags 库的其他命令行参数 引言 gflags 是 Google 开发的一个开源库&#xff0c;用于 C 应用程序中命令行参数的声明、定义 和解析。 gflags 库提供了一种简单的方式来添加、解析和文档化命令行标…...

金融问答系统:如何用大语言模型打造高精度合规的金融知识引擎

假如我现在向大模型提问&#xff0c;我的问题是&#xff1a;请查询在2021年度&#xff0c;68**38股票涨停天数&#xff1f; 或者我问&#xff1a;湖南*****科股份有限公司变更设立时作为发起人的法人有哪些&#xff1f; 大模型巴拉巴拉给我一个答案&#xff0c;那怎么让我信任大…...

Spring WebFlux与Quarkus实战:云原生微服务开发的两大主流框架深度解析

简介 云原生与微服务架构已成为企业数字化转型的核心驱动力,而Spring WebFlux和Quarkus作为两大主流框架,各自提供了独特的解决方案来应对高并发、低延迟和快速启动的挑战。本文将从零开始,详细讲解如何使用这两个框架构建高性能的云原生微服务,并通过实际案例展示它们在企…...

成功案例丨从草图到鞍座:用先进的发泡成型仿真技术变革鞍座制造

案例简介 在鞍座制造中&#xff0c;聚氨酯泡沫成型工艺是关键环节&#xff0c;传统依赖实验测试的方法耗时且成本高昂。为解决这一问题&#xff0c;意大利自行车鞍座制造商 Selle Royal与Altair合作&#xff0c;采用Altair Inspire PolyFoam软件进行发泡成型仿真。 该工具帮助团…...

学习日志09 java

我要(ง •_•)ง&#xff01;&#xff01; 1 面向对象里面的编程的属性&#xff0c;其实就是变量啦 在面向对象编程里&#xff0c;“属性”&#xff08;Attribute&#xff09;也被叫做 “成员变量” 或者 “字段”&#xff08;Field&#xff09;&#xff0c;指的是类中用来存…...

深入解析Spring Boot与微服务架构:从入门到实践

深入解析Spring Boot与微服务架构&#xff1a;从入门到实践 引言 随着云计算和分布式系统的普及&#xff0c;微服务架构已成为现代软件开发的主流模式。Spring Boot作为Java生态中最受欢迎的框架之一&#xff0c;为开发者提供了快速构建微服务的强大工具。本文将深入探讨Spri…...

25考研经验贴(11408)

声明&#xff1a;以下内容都仅代表个人观点 数学一&#xff08;130&#xff09; 25考研数学一难度介绍&#xff1a;今年数学一整体不难&#xff0c;尤其是选填部分&#xff0c;大题的二型线面和概率论大题个人感觉比较奇怪&#xff0c;其他大题还是比较容易的。.26如何准备&a…...

Linux运行时的参数、命令、网络、磁盘参数和日志监控

一、监控 1. free 功能&#xff1a;用于查看系统内存使用情况&#xff0c;包括物理内存总量、已用内存、空闲内存、缓冲区&#xff08;buffer&#xff09;和缓存&#xff08;cache&#xff09;占用&#xff0c;以及交换内存&#xff08;swap&#xff09;的使用与剩余情况。常…...

Spring Boot循环依赖的陷阱与解决方案:如何打破“Bean创建死循环”?

引言 在Spring Boot开发中&#xff0c;你是否遇到过这样的错误信息&#xff1f; The dependencies of some of the beans in the application context form a cycle 这表示你的应用出现了循环依赖。尽管Spring框架通过巧妙的机制解决了部分循环依赖问题&#xff0c;但在实际开…...

如何打造MVP(最小可行性产品)(MVP=核心功能+快速验证+用户反馈+持续迭代)

文章目录 **一、MVP的核心原则**1. **聚焦核心价值**2. **快速迭代**3. **低成本验证** **二、MVP的打造步骤****1. 定义目标用户和核心需求****2. 确定MVP的核心功能**- **筛选关键功能**&#xff1a;1. 用户是否愿意为这个功能付费&#xff1f;2. 实现该功能的技术难度和成本…...

conda init执行了还是不好用

按照gpt的方法&#xff0c;还是方法一&#xff1a;以管理员身份运行 PowerShell 并设置执行策略 好用 你遇到的问题是典型的 Conda 环境激活失败 错误&#xff0c;提示如下&#xff1a; CondaError: Run conda init before conda activate但你已经运行了 conda init&#xff…...

crontab 定时任务不执行问题排查

*/5 * * * * sh /data03/jq/sparkjob.sh 定时任务不执行&#xff01; Cron默认丢弃输出&#xff0c;错误信息无法查看。 将输出和错误重定向到日志文件&#xff1a; /bin/sh /data03/jq/sparkjob.sh >> /tmp/sparkjob.log 2>&1 检查日志文件 /tmp/sparkjob.log 定…...

require/exports 或 import/export的联系和区别,各自的使用场景

以下是 require/exports&#xff08;CommonJS&#xff09;与 import/export&#xff08;ES6 Modules&#xff09;的对比分析及使用场景说明&#xff1a; 一、核心联系‌ ‌模块化目标‌ 两者都用于实现代码模块化&#xff0c;解决全局作用域污染和依赖管理问题。 ‌跨环境适配‌…...

如何更改远程桌面连接的默认端口?附外网访问内网计算机方法

远程连接端口根据协议和场景不同有所差异&#xff0c;以下是常见远程连接端口的设置及修改方法&#xff0c;同时附外网访问内网计算机操作。 一、Windows远程桌面默认端口 ‌默认端口‌&#xff1a;3389&#xff08;TCP协议&#xff09;&#xff0c;用于Windows远程桌面服务&…...

模拟jenkins+k8s自动化部署

参考 Jenkins+k8s实现自动化部署 - 掘金 手把手教你用 Jenkins + K8S 打造流水线环境 - 简书 安装插件 调整插件升级站点 (提高插件下载速度) 默认地址 https://updates.jenkins.io/update-center.json 新地址 http://mirror.xmission.com/jenkins/updates/update-center.json …...

Jenkins教程

参考 Jenkins 用户手册 Jenkins User Documentation 在项目创建Jenkinsfile文件 添加分支源 报错 不自动拉取分支,改为手工指定分支 又报了一个错, 解决方法,参考: Jenkins中连接Git仓库时提示:无法连接仓库:Error performing git command: git ls-remote -h_霸道流…...

从验证码绕过到信息轰炸:全面剖析安全隐患与防范策略

在数字化交互场景中&#xff0c;验证码作为区分人类操作与自动化程序的核心屏障&#xff0c;广泛应用于用户身份核验、操作权限确认等关键环节。其设计初衷是通过人机识别机制&#xff0c;保障信息系统交互的安全性与可控性。然而&#xff0c;当验证码验证机制出现异常突破&…...

CSS:颜色的三种表示方式

文章目录 一、rgb和rgba方式二、HEX和HEXA方式&#xff08;推荐&#xff09;三、hsl和hsla方式四、颜色名方式 一、rgb和rgba方式 10进制表示方法 二、HEX和HEXA方式&#xff08;推荐&#xff09; 就是16进制表示法 三、hsl和hsla方式 语法&#xff1a;hsl(hue, satura…...

math toolkit for real-time development读书笔记一-三角函数快速计算(1)

一、基础知识 根据高中知识我们知道&#xff0c;很多函数都可以用泰勒级数展开。正余弦泰勒级数展开如下&#xff1a; 将其进一步抽象为公式可知&#xff1a; 正弦和余弦的泰勒级数具有高度结构化的模式&#xff0c;可拆解为以下核心特征&#xff1a; 1. 符号交替特性 正弦级…...

超市营业额数据分析

1.推出5名销冠 2.新领导想看看他15天以来的业绩总增长情况,以及增长额前3的柜台 3.把所有柜台的销售额分为3个等级 import pandas as pd import matplotlib.pyplot as plt import numpy as np# 设置中文字体和显示方式 plt.rcParams.update({font.sans-serif&...

labelimg安装及使用指南(yolo)

1.安装 首先要安装Anaconda&#xff0c;然后打开Anaconda Prompt 构建一个新的虚拟环境&#xff08;注&#xff1a;虚拟环境的python的版本应在3.9及以下&#xff0c;不然会在运行中报错&#xff09; conda create -n label python3.9 其中这里label只是一个名字&#xff0c;…...

在 Ubuntu 系统中,将 JAR 包安装为服务

在 Ubuntu 系统中&#xff0c;将 JAR 包安装为服务可以通过 systemd 来实现。以下是详细的操作步骤&#xff1a; 准备工作 确保 JAR 文件路径和 Java 运行时环境已准备好。验证 Java 是否可用&#xff1a; java -version创建 systemd 服务文件 systemd 的服务文件通常位于 …...

我的 PDF 工具箱:CodeBuddy 打造 PDFMagician 的全过程记录

我正在参加CodeBuddy「首席试玩官」内容创作大赛&#xff0c;本文所使用的 CodeBuddy 免费下载链接&#xff1a;腾讯云代码助手 CodeBuddy - AI 时代的智能编程伙伴 最近&#xff0c;我萌生了一个念头&#xff1a;能不能自己动手做一个功能丰富的 PDF 工具箱&#xff1f;市面上…...

WebSocket聊天室的简单制作指南

一、前言 最近在学习WebSocket技术&#xff0c;做了一个简单的聊天室Demo。这个项目虽然不大&#xff0c;但涵盖了WebSocket的核心功能实现。下面我将详细介绍这个聊天室的实现过程&#xff0c;希望能帮助到同样想学习WebSocket的朋友们。 二、技术选型 后端&#xff1a;Spri…...

非国产算力DeepSeek 部署中的常见问题及解决方案

随着大语言模型&#xff08;LLM&#xff09;在企业级应用场景中的快速推进&#xff0c;DeepSeek 一体机凭借其高性能推理能力和便捷的系统集成优势&#xff0c;正逐步成为多行业智能化转型的重要基础设施。然而&#xff0c;在实际部署过程中&#xff0c;技术团队常常会遭遇一系…...

大数据技术的主要方向及其应用详解

文章目录 一、大数据技术概述二、大数据存储与管理方向1. 分布式文件系统2. NoSQL数据库3. 数据仓库技术 三、大数据处理与分析方向1. 批处理技术2. 流处理技术3. 交互式分析4. 图计算技术 四、大数据机器学习方向1. 分布式机器学习2. 深度学习平台3. 自动机器学习(AutoML) 五、…...

Maven使用详解:Maven的概述(二)

一、核心定义与功能 Maven是由Apache软件基金会开发的开源项目管理工具&#xff0c;专为Java项目设计&#xff0c;主要用于自动化构建、依赖管理和项目标准化。其核心功能包括&#xff1a; 依赖管理&#xff1a;通过pom.xml文件声明依赖库&#xff0c;自动从中央仓库下载并管…...

在 Odoo 18 表单视图中使用 JS 类的方法

在 Odoo 18 表单视图中使用 JS 类的方法 一、模块结构创建 要为特定视图在 JavaScript 里注册一个类。后续在任意表单视图中添加相同类时&#xff0c;自定义视图就会被注入该表单。 具体要做的是&#xff1a; 把自定义视图创建出来当作模板。将视图注册成一个组件。把它和表…...

ubuntu 更新华为源

1. 备份配置文件 sudo cp -a /etc/apt/sources.list /etc/apt/sources.list.bak 2. 修改source.list 文件&#xff0c;将http://archive.ubuntu.com和http://security.ubuntu.com替换成http://repo.huaweicloud.com&#xff0c;可以参考如下命令&#xff1a; # 第一条指令 s…...

如何安装cuda版本的pytorch

为什么安装Cuda 对于做深度学习研究的小伙伴本&#xff0c;当我们处理大量的数据时&#xff0c;尤其是图像数据时&#xff0c;过量的数据会导致我们的CPU运行压力过大&#xff0c;占用大量的运行内存&#xff0c;而且用CPU进行模型训练&#xff0c;训练的时间会很长&#xff0…...

国际名校教育大模型的构建与教学应用实践

一、引言 全球AI数字教育正在快速发展,人工智能技术已成为推动教育变革的核心驱动力。从个性化学习到智能评测,从虚拟助教到自适应教学系统,AI正在重塑教育的形态。在此背景下,国际顶尖高校纷纷布局教育大模型,探索AI与教学的深度融合,以提升教育质量、优化学习体验。与…...

postgres的docker版本安装

postgres的docker版本安装 背景 测试和开发需要用到postgres&#xff0c;越快越好&#xff0c;想到了用docker进行安装。 sudo docker run -d -p 5432:5432 --restartalways -v /home/docker/postgre/data:/var/lib/postgresql/data -e POSTGRES_PASSWORD123456 --name p…...

知识蒸馏实战:用PyTorch和预训练模型提升小模型性能

在深度学习的浪潮中&#xff0c;我们常常追求更大、更深、更复杂的模型以达到最先进的性能。然而&#xff0c;这些“庞然大物”般的模型往往伴随着高昂的计算成本和缓慢的推理速度&#xff0c;使得它们难以部署在资源受限的环境中&#xff0c;如移动设备或边缘计算平台。知识蒸…...

【HTML 全栈进阶】从语义化到现代 Web 开发实战

目录 &#x1f31f; 前言&#x1f3d7;️ 技术背景与价值&#x1fa79; 当前技术痛点&#x1f6e0;️ 解决方案概述&#x1f465; 目标读者说明 &#x1f9e0; 一、技术原理剖析&#x1f4ca; 核心概念图解&#x1f4a1; 核心作用讲解&#x1f527; 关键技术模块说明⚖️ 技术选…...

Transformer 模型与注意力机制

目录 Transformer 模型与注意力机制 一、Transformer 模型的诞生背景 二、Transformer 模型的核心架构 &#xff08;一&#xff09;编码器&#xff08;Encoder&#xff09; &#xff08;二&#xff09;解码器&#xff08;Decoder&#xff09; 三、注意力机制的深入剖析 …...

机器学习数据预处理回归预测中标准化和归一化

在机器学习的回归预测任务中&#xff0c;** 标准化&#xff08;Standardization&#xff09;和归一化&#xff08;Normalization&#xff09;** 是数据预处理的重要步骤&#xff0c;用于消除不同特征量纲和取值范围的影响&#xff0c;提升模型训练效率和预测性能。 一、标准化…...

B2C 商城转型指南:传统企业如何用 ZKmall模板商城实现电商化

在数字化浪潮席卷全球的当下&#xff0c;传统企业向电商转型已不再是选择题&#xff0c;而是关乎生存与发展的必答题。然而&#xff0c;缺乏技术积累、开发成本高、运营经验不足等问题&#xff0c;成为传统企业转型路上的 “拦路虎”。ZKmall模板商城以其低门槛、高灵活、强适配…...

FPGA:Lattice的FPGA产品线以及器件选型建议

本文将详细介绍Lattice Semiconductor的FPGA产品线&#xff0c;帮助你了解各系列的特点和适用场景&#xff0c;以便更好地进行选型。Lattice以低功耗、小尺寸和高性能为核心&#xff0c;产品覆盖低中端市场&#xff0c;广泛应用于通信、计算、工业、汽车、消费电子、嵌入式视觉…...

学习51单片机02

吐血了&#xff0c;板子今天才到&#xff0c;下午才刚开始学的&#xff0c;生气了&#xff0c;害我笔记都断更了一天。。。。 紧接上文...... 如何将HEX程序烧写到程序? Tips&#xff1a;HEX 文件是一种常用于单片机等嵌入式系统的文件格式&#xff0c;它包含了程序的机器码…...

武汉SMT贴片工艺优化与生产效能提升路径

内容概要 随着华中地区电子制造产业集群的快速发展&#xff0c;武汉SMT贴片行业面临工艺升级与效能提升的双重挑战。本文聚焦SMT生产全流程中的关键环节&#xff0c;从钢网印刷精度控制、回流焊温度曲线优化、AOI检测系统迭代三大核心工艺出发&#xff0c;结合区域产业链特点提…...

LineBasicMaterial

LineBasicMaterial 描述 用于绘制纯色线条的基础材质&#xff0c;支持颜色、线宽和纹理映射。常用于THREE.Line或THREE.LineSegments几何体。 构造函数 (Constructor) 构造函数参数描述LineBasicMaterial(parameters?: Object)parameters定义材质外观的对象&#xff0c;可…...

虚拟机安装达梦数据库

准备 关闭SELINUX # setenforce 0 # vi /etc/selinux/config 修改SELINUXdisabled 上传达梦ISO 接下下载的达梦安装包&#xff0c;里面包含一个ISO文件&#xff0c;将其上传到CentOS的/tmp路径下安装达梦所需图形类库 # yum install -y gtk2 libXtst xorg-x11-…...

小波变换+注意力机制成为nature收割机

小波变换作为一种新兴的信号分析工具&#xff0c;能够高效地提取信号的局部特征&#xff0c;为复杂数据的处理提供了有力支持。然而&#xff0c;它在捕捉数据中最为关键的部分时仍存在局限性。为了弥补这一不足&#xff0c;我们引入了注意力机制&#xff0c;借助其能够强化关注…...

科技项目验收测试对软件产品和企业分别有哪些好处?

科技项目验收测试是指在项目的开发周期结束后&#xff0c;针对项目成果进行的一系列验证和确认活动。其目的是确保终交付的产品或系统符合预先设定的需求和标准。验收测试通常包括功能测试、性能测试、安全测试等多个方面&#xff0c;帮助企业评估软件在实际应用中的表现。 科…...

ChatGPT到Claude全适配:跨模型Prompt高级设计规范与迁移技巧

本文较长&#xff0c;建议点赞收藏&#xff0c;以免遗失。更多AI大模型应用开发学习内容&#xff0c;尽在聚客AI学院。 一. 迭代优化&#xff1a;基于反馈的Prompt进化策略 1.1 优化闭环设计 初始Prompt → 生成结果 → 人工评估 → 问题分析 → 改进Prompt 代码示例&#x…...

NexBot AI 1.9.3 | 专业AI写作助手,高自由度定制内容,支持中文设置

NexBot AI是一款强大的人工智能助手应用程序&#xff0c;旨在帮助用户快速生成符合其需求的内容。通过高自由度的关键词和短语合并功能&#xff0c;用户可以根据自己的具体要求定制内容。该应用能够迅速生成多种输出结果供用户选择&#xff0c;非常适合需要高效工作流程的专业人…...