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

CAPL概述与环境搭建

CAPL概述与环境搭建

目录

  • CAPL概述与环境搭建
    • 1. CAPL简介与应用领域
      • 1.1 CAPL简介
      • 1.2 CAPL的应用领域
    • 2. CANoe/CANalyzer 安装与配置
      • 2.1 CANoe/CANalyzer 简介
      • 2.2 安装CANoe/CANalyzer
        • 2.2.1 系统要求
        • 2.2.2 安装步骤
      • 2.3 配置CANoe/CANalyzer
        • 2.3.1 配置CAN通道
        • 2.3.2 配置CAPL节点
    • 3. CAPL Browser 使用指南
      • 3.1 CAPL Browser 简介
      • 3.2 CAPL Browser 界面介绍
      • 3.3 CAPL脚本的基本结构
      • 3.4 CAPL脚本的调试
        • 3.4.1 设置断点
        • 3.4.2 查看变量值
        • 3.4.3 单步执行
      • 3.5 CAPL脚本的编译与运行
      • 3.6 CAPL脚本的常用函数
      • 3.7 CAPL脚本的调试技巧
    • 4. CAPL脚本的进阶应用
      • 4.1 复杂事件处理
      • 4.2 定时器的使用
      • 4.3 环境变量的使用
      • 4.4 CAPL脚本的模块化设计
    • 5. CAPL脚本的性能优化
      • 5.1 减少不必要的操作
      • 5.2 使用高效的算法
      • 5.3 优化消息处理
    • 6. CAPL脚本的测试与验证
      • 6.1 单元测试
      • 6.2 集成测试
      • 6.3 性能测试
    • 7. 总结
    • 8. 流程图示例
    • 9. 代码示例
    • 10. 结语

1. CAPL简介与应用领域

1.1 CAPL简介

CAPL(Communication Access Programming Language)是Vector公司开发的一种用于汽车电子系统开发和测试的脚本语言。它主要用于CANoe和CANalyzer工具中,用于模拟、测试和分析CAN(Controller Area Network)网络。CAPL语言基于C语言,具有类似C语言的语法结构,因此对于熟悉C语言的开发者来说,学习和使用CAPL会相对容易。

CAPL的主要特点包括:

  • 事件驱动:CAPL程序是基于事件驱动的,开发者可以定义各种事件(如消息接收、定时器触发等)来触发相应的操作。
  • 丰富的API:CAPL提供了丰富的API接口,可以方便地访问CAN网络中的消息、信号、环境变量等。
  • 强大的调试功能:CAPL支持在CANoe/CANalyzer中进行实时调试,开发者可以设置断点、查看变量值、单步执行等。

1.2 CAPL的应用领域

CAPL广泛应用于汽车电子系统的开发、测试和验证过程中,主要包括以下几个方面:

  • 网络模拟:在汽车电子系统的开发过程中,通常需要模拟整个CAN网络的行为。CAPL可以用于编写模拟节点,模拟ECU(Electronic Control Unit)的发送和接收行为。
  • 自动化测试:CAPL可以用于编写自动化测试脚本,对CAN网络中的消息、信号进行自动化测试,验证系统的功能和性能。
  • 故障注入:在测试过程中,CAPL可以用于模拟网络中的故障,如消息丢失、信号错误等,以验证系统的容错能力。
  • 数据分析:CAPL可以用于对CAN网络中的数据进行分析,提取有用的信息,生成测试报告。

2. CANoe/CANalyzer 安装与配置

2.1 CANoe/CANalyzer 简介

CANoe和CANalyzer是Vector公司开发的两款用于汽车电子系统开发和测试的工具。CANoe主要用于网络开发、仿真和测试,而CANalyzer则主要用于网络分析和诊断。两者都支持CAPL脚本语言,可以用于编写复杂的测试脚本和仿真模型。

2.2 安装CANoe/CANalyzer

2.2.1 系统要求

在安装CANoe/CANalyzer之前,需要确保计算机满足以下系统要求:

  • 操作系统:Windows 7/8/10(64位)
  • 处理器:Intel Core i5或更高
  • 内存:8GB或更高
  • 硬盘空间:至少20GB可用空间
  • 显卡:支持OpenGL 2.0或更高
2.2.2 安装步骤
  1. 下载安装包:从Vector官网下载CANoe/CANalyzer的安装包。
  2. 运行安装程序:双击安装包,启动安装程序。
  3. 选择安装类型:选择“典型安装”或“自定义安装”。典型安装会安装所有组件,而自定义安装可以选择需要安装的组件。
  4. 配置安装路径:选择安装路径,建议使用默认路径。
  5. 安装完成:等待安装程序完成安装,点击“完成”按钮退出安装程序。

2.3 配置CANoe/CANalyzer

2.3.1 配置CAN通道

在CANoe/CANalyzer中,首先需要配置CAN通道,以便与实际的CAN网络进行通信。

  1. 打开CANoe/CANalyzer:启动CANoe/CANalyzer软件。
  2. 创建新工程:点击“File” -> “New” -> “Configuration”,创建一个新的工程。
  3. 添加CAN通道:在“Hardware”选项卡中,点击“Add”按钮,添加CAN通道。选择正确的硬件接口(如Vector CAN接口卡)和波特率(如500kbps)。
  4. 保存配置:点击“Save”按钮,保存配置。
2.3.2 配置CAPL节点

在CANoe/CANalyzer中,可以通过CAPL节点来模拟ECU的行为。

  1. 添加CAPL节点:在“Simulation Setup”选项卡中,右键点击“Network Nodes”,选择“Insert CAPL Node”。
  2. 编写CAPL脚本:双击CAPL节点,打开CAPL Browser,编写CAPL脚本。
  3. 编译CAPL脚本:点击“Compile”按钮,编译CAPL脚本。如果编译成功,CAPL节点将出现在仿真网络中。

3. CAPL Browser 使用指南

3.1 CAPL Browser 简介

CAPL Browser是CANoe/CANalyzer中用于编写、编辑和调试CAPL脚本的工具。它提供了一个集成的开发环境,支持语法高亮、代码自动补全、调试等功能。

3.2 CAPL Browser 界面介绍

CAPL Browser的界面主要分为以下几个部分:

  • 菜单栏:包含文件操作、编辑、编译、调试等功能。
  • 工具栏:提供常用功能的快捷按钮,如新建、打开、保存、编译、运行等。
  • 代码编辑区:用于编写和编辑CAPL脚本。
  • 输出窗口:显示编译和调试过程中的输出信息。
  • 变量窗口:显示当前脚本中的变量及其值。

3.3 CAPL脚本的基本结构

一个典型的CAPL脚本通常包括以下几个部分:

  • 变量声明:声明脚本中使用的变量。
  • 事件处理函数:定义各种事件的处理函数,如消息接收、定时器触发等。
  • 主函数:脚本的入口函数,通常用于初始化操作。

以下是一个简单的CAPL脚本示例:

variables
{message 0x100 msg1;int count = 0;
}on message msg1
{count++;write("Received message 0x100, count = %d", count);
}on start
{write("CAPL script started");
}

3.4 CAPL脚本的调试

CAPL Browser提供了强大的调试功能,可以帮助开发者快速定位和解决问题。

3.4.1 设置断点

在代码编辑区中,点击行号左侧的空白区域,可以设置断点。当脚本运行到断点时,程序会暂停,开发者可以查看变量的值、单步执行代码等。

3.4.2 查看变量值

在调试过程中,可以在变量窗口中查看当前脚本中的变量及其值。也可以通过write函数将变量的值输出到输出窗口中。

3.4.3 单步执行

在调试过程中,可以使用“Step Over”、“Step Into”、“Step Out”等按钮进行单步执行,逐步查看脚本的执行过程。

3.5 CAPL脚本的编译与运行

在编写完CAPL脚本后,需要先进行编译,然后才能运行。

  1. 编译脚本:点击工具栏中的“Compile”按钮,编译脚本。如果编译成功,输出窗口会显示“Compilation successful”。
  2. 运行脚本:点击工具栏中的“Run”按钮,运行脚本。脚本开始运行后,可以在输出窗口中查看脚本的输出信息。

3.6 CAPL脚本的常用函数

CAPL提供了丰富的API函数,以下是一些常用的函数:

  • 消息发送output(msg),用于发送CAN消息。
  • 消息接收on message,用于处理接收到的CAN消息。
  • 定时器setTimer(timer, time),用于设置定时器。
  • 环境变量getEnvironmentVariable(var),用于获取环境变量的值。
  • 日志输出write("message"),用于输出日志信息。

3.7 CAPL脚本的调试技巧

在调试CAPL脚本时,可以采用以下技巧来提高调试效率:

  • 使用断点:在关键代码处设置断点,逐步查看脚本的执行过程。
  • 输出调试信息:使用write函数输出变量的值或调试信息,帮助定位问题。
  • 单步执行:通过单步执行,逐步查看脚本的执行过程,找出问题所在。
  • 查看变量值:在调试过程中,查看变量的值,确保变量的值符合预期。

4. CAPL脚本的进阶应用

4.1 复杂事件处理

在实际应用中,CAPL脚本可能需要处理多个事件,并且这些事件之间可能存在复杂的逻辑关系。以下是一个复杂事件处理的示例:

variables
{message 0x100 msg1;message 0x200 msg2;int count1 = 0;int count2 = 0;
}on message msg1
{count1++;write("Received message 0x100, count1 = %d", count1);if (count1 > 10){output(msg2);}
}on message msg2
{count2++;write("Received message 0x200, count2 = %d", count2);if (count2 > 5){stopSimulation();}
}on start
{write("CAPL script started");
}

在这个示例中,脚本处理了两个消息msg1msg2。当msg1的接收次数超过10次时,脚本会发送msg2;当msg2的接收次数超过5次时,脚本会停止仿真。

4.2 定时器的使用

定时器是CAPL脚本中常用的功能之一,可以用于定时触发某些操作。以下是一个定时器使用的示例:

variables
{message 0x100 msg1;msTimer timer1;int count = 0;
}on timer timer1
{count++;write("Timer triggered, count = %d", count);output(msg1);if (count < 10){setTimer(timer1, 1000);}
}on start
{write("CAPL script started");setTimer(timer1, 1000);
}

在这个示例中,脚本设置了一个定时器timer1,每隔1秒触发一次。每次定时器触发时,脚本会发送msg1,并在输出窗口中输出计数器的值。当计数器达到10次时,定时器停止。

4.3 环境变量的使用

环境变量是CAPL脚本中用于与外部环境进行交互的一种机制。以下是一个环境变量使用的示例:

variables
{int value;
}on start
{value = getEnvironmentVariable("MyVar");write("Environment variable MyVar = %d", value);
}

在这个示例中,脚本在启动时获取环境变量MyVar的值,并将其输出到输出窗口中。

4.4 CAPL脚本的模块化设计

在实际项目中,CAPL脚本可能会变得非常复杂。为了提高代码的可读性和可维护性,可以采用模块化设计的方法,将脚本分解为多个模块。以下是一个模块化设计的示例:

// Module1.can
variables
{message 0x100 msg1;int count = 0;
}on message msg1
{count++;write("Received message 0x100, count = %d", count);
}// Module2.can
variables
{message 0x200 msg2;int count = 0;
}on message msg2
{count++;write("Received message 0x200, count = %d", count);
}// Main.can
#include "Module1.can"
#include "Module2.can"on start
{write("CAPL script started");
}

在这个示例中,脚本被分解为三个模块:Module1.canModule2.canMain.canMain.can通过#include指令引入了其他两个模块,从而实现了模块化设计。

5. CAPL脚本的性能优化

5.1 减少不必要的操作

在编写CAPL脚本时,应尽量减少不必要的操作,以提高脚本的执行效率。例如,避免在循环中进行复杂的计算或频繁的I/O操作。

5.2 使用高效的算法

在处理大量数据时,应尽量使用高效的算法,以减少脚本的执行时间。例如,使用哈希表来快速查找数据,而不是使用线性查找。

5.3 优化消息处理

在CAN网络中,消息的处理速度对系统的性能有很大影响。因此,在编写CAPL脚本时,应尽量优化消息的处理逻辑,减少消息处理的延迟。

6. CAPL脚本的测试与验证

6.1 单元测试

在编写CAPL脚本时,应进行单元测试,验证每个模块的功能是否正确。可以使用CANoe/CANalyzer中的测试工具进行单元测试。

6.2 集成测试

在完成所有模块的单元测试后,应进行集成测试,验证整个脚本的功能是否正确。可以使用CANoe/CANalyzer中的仿真功能进行集成测试。

6.3 性能测试

在完成功能测试后,应进行性能测试,验证脚本的执行效率是否符合要求。可以使用CANoe/CANalyzer中的性能分析工具进行性能测试。

7. 总结

CAPL是一种功能强大的脚本语言,广泛应用于汽车电子系统的开发、测试和验证过程中。通过本文的介绍,读者可以了解CAPL的基本概念、应用领域、环境搭建、脚本编写与调试等内容。希望本文能够帮助读者快速掌握CAPL的使用方法,并在实际项目中应用CAPL进行开发和测试。

8. 流程图示例

以下是一个使用mermaid语法绘制的流程图示例,展示了CAPL脚本的基本执行流程:

消息接收
定时器触发
仿真停止
开始
初始化变量
等待事件
事件类型
处理消息
处理定时器
结束

在这个流程图中,脚本首先初始化变量,然后进入事件循环,等待事件的发生。根据事件的类型,脚本会执行相应的处理逻辑,然后继续等待下一个事件。当仿真停止时,脚本结束执行。

9. 代码示例

以下是一个使用CAPL实现的简单示例,展示了如何发送和接收CAN消息:

variables
{message 0x100 msg1;message 0x200 msg2;int count = 0;
}on message msg1
{count++;write("Received message 0x100, count = %d", count);if (count > 10){output(msg2);}
}on message msg2
{write("Received message 0x200");stopSimulation();
}on start
{write("CAPL script started");output(msg1);
}

在这个示例中,脚本首先发送msg1,然后等待接收msg1。当msg1的接收次数超过10次时,脚本会发送msg2,并在接收到msg2时停止仿真。

10. 结语

通过本文的学习,读者应该对CAPL有了初步的了解,并能够使用CAPL进行简单的脚本编写和调试。在实际项目中,CAPL的应用非常广泛,希望读者能够通过不断的学习和实践,掌握更多的CAPL技巧,提高自己的开发能力。

相关文章:

CAPL概述与环境搭建

CAPL概述与环境搭建 目录 CAPL概述与环境搭建1. CAPL简介与应用领域1.1 CAPL简介1.2 CAPL的应用领域 2. CANoe/CANalyzer 安装与配置2.1 CANoe/CANalyzer 简介2.2 安装CANoe/CANalyzer2.2.1 系统要求2.2.2 安装步骤 2.3 配置CANoe/CANalyzer2.3.1 配置CAN通道2.3.2 配置CAPL节点…...

Virgo:增强慢思考推理能力的多模态大语言模型

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…...

偃动访无穿戴动作捕捉系统:赋能多行业开启动作捕捉新篇章

在当今科技飞速发展的时代&#xff0c;动作捕捉技术正以前所未有的态势深入到社会发展的各个领域&#xff0c;成为众多行业不可或缺的重要助力。从早期的惯性动捕与光捕技术&#xff0c;到如今更为先进的无标记动捕技术&#xff0c;动作捕捉领域不断迎来革新与突破。 无标记动…...

mikro-orm 和typeorm 对比

以下是Mikro-ORM和TypeORM的详细对比&#xff1a; 设计理念与架构 Mikro-ORM&#xff1a;基于数据映射器、工作单元和身份映射模式。这种设计使得它在管理内存中实体状态方面表现优异&#xff0c;能够自动处理事务&#xff0c;当调用em.flush()时&#xff0c;所有计算出的更改…...

Docker入门之docker基本命令

Docker入门之docker基本命令 官方网站&#xff1a;https://www.docker.com/ 1. 拉取官方镜像并创建容器&#xff08;以redis为例&#xff09; 拉取官方镜像 docker pull redis# 如果不需要添加到自定义网络使用这个命令&#xff0c;如需要&#xff0c;直接看第二步 docker r…...

mysql的一些函数及其用法

mysql 1-来自于leetcode1517的题目 表: Users------------------------ | Column Name | Type | ------------------------ | user_id | int | | name | varchar | | mail | varchar | ------------------------已知一个表&#xff0c;它的…...

NO.3 《机器学习期末复习篇》以题(问答题)促习(人学习),满满干huo,大胆学大胆补!

目录 &#x1f50d; 1. 对于非齐次线性模型 &#xff0c;试将其表示为齐次线性模型形式。 ​编辑 &#x1f50d; 2. 某汽车公司一年内各月份的广告投入与月销量数据如表3-28所示&#xff0c;试根据表中数据构造线性回归模型&#xff0c;并使用该模型预测月广告投入为20万元时…...

黑马跟学.苍穹外卖.Day03

黑马跟学.苍穹外卖.Day03 苍穹外卖-day03课程内容1. 公共字段自动填充1.1 问题分析1.2 实现思路1.3 代码开发1.3.1 步骤一1.3.2 步骤二1.3.3 步骤三 1.4 功能测试1.5 代码提交 2. 新增菜品2.1 需求分析与设计2.1.1 产品原型2.1.2 接口设计2.1.3 表设计 2.2 代码开发2.2.1 文件上…...

js -音频变音(听不出说话的人是谁)

学习参考来源&#xff1a; https://zhuanlan.zhihu.com/p/634848804 https://developer.mozilla.org/zh-CN/docs/Web/API/Web_Audio_API 实际效果&#xff1a; http://www.qingkong.zone/laboratory?typeaudio-confusion 前言 本文内容可结合上面学习参考来源&#xff0c;结合…...

鸿蒙UI(ArkUI-方舟UI框架)

参考&#xff1a;https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V13/arkts-layout-development-overview-V13 ArkUI简介 ArkUI&#xff08;方舟UI框架&#xff09;为应用的UI开发提供了完整的基础设施&#xff0c;包括简洁的UI语法、丰富的UI功能&#xff…...

常见的http状态码 + ResponseEntity

常见的http状态码 ResponseStatus(HttpStatus.CREATED) 是 Spring Framework 中的注解&#xff0c;用于指定 HTTP 响应状态码。 1. 基本说明 HttpStatus.CREATED 对应 HTTP 状态码 201表示请求成功且创建了新的资源通常用于 POST 请求的处理方法上 2. 使用场景和示例 基本…...

pikachu - Cross-Site Scripting(XSS)

pikachu - Cross-Site Scripting&#xff08;XSS&#xff09; 声明&#xff01; 笔记只是方便各位师傅的学习和探讨&#xff0c;文章所提到的网站以及内容&#xff0c;只做学习交流&#xff0c;其他均与本人无关&#xff0c;切勿触碰法律底线&#xff0c;否则后果自负&#x…...

操作系统之文件系统的基本概念

目录 用户和磁盘视角的文件 文件控制块&#xff08;FCB&#xff09;和索引结点&#xff08;inode&#xff09; 文件的操作 创建文件&#xff08;create系统调用&#xff09; 写文件&#xff08;write系统调用&#xff09; 读文件&#xff08;read系统调用&#xff09; 重…...

深入探讨 Android 中的 AlarmManager:定时任务调度及优化实践

引言 在 Android 开发中&#xff0c;AlarmManager 是一个非常重要的系统服务&#xff0c;用于设置定时任务或者周期性任务。无论是设置一个闹钟&#xff0c;还是定时进行数据同步&#xff0c;AlarmManager 都是不可或缺的工具之一。然而&#xff0c;随着 Android 系统的不断演…...

西电-算法分析-研究生课程复习笔记

24年秋的应该是张老师最后一次用卷面考试&#xff0c;他说以后这节课的期末考试都是在OJ上刷题了张老师上课还挺有意思的&#xff0c;上完之后能学会独立地思考算法设计问题了。整节课都在强调规模压缩这个概念&#xff0c;考试也是考个人对这些的理解&#xff0c;还挺好玩的哈…...

编译时找不到需要的库,如何在PyCharm中为你的项目添加需要的库

丰富的库支持是 Python 语言的一大特点&#xff0c;但是在使用 PyCharm 进行Python 代码编译的时候&#xff0c;遇到一些需要使用到的库提示不能解析时&#xff0c;该如何添加呢&#xff1f; 比如下图所示的代码&#xff0c;可以看到需要使用 selenium、b4、jieba 这些库&…...

ip addr 命令给Linux网络接口配置多个IP地址值

问一下Chatgpt 怎么使用ip addr 命令给Linux网络接口配置多个IP地址值 根据Chatgpt的提示执行了命令&#xff0c;命令执行成功&#xff0c;看下执行结果。 ifconfig 命令查看接口IP地址 ip addr show 命令查看接口IP地址...

C#语言的数据库编程

C#语言的数据库编程 在现代软件开发中&#xff0c;数据库是不可或缺的一部分。无论是企业级应用还是个人项目&#xff0c;数据的存储与管理都是程序的核心功能之一。C#作为一种强类型、面向对象的编程语言&#xff0c;广泛应用于Windows平台的开发&#xff0c;尤其是在构建与数…...

时频分析之S变换

S变换的提出 1996年&#xff0c;由R.G Stockwell 提出了S变换&#xff0c;和其他时频分析工具一样&#xff0c;通过S变换&#xff0c;我们可以同时从时域以及频域观察一个信号的能量分布。S变换融合了短时傅里叶变换和小波变换的优点。关于S变换&#xff0c;最早发表于TSP上的…...

第二十八周学习周报

目录 摘要Abstract1 GFPGAN1.1 总体结构1.2 实验研究1.3 代码分析 总结 摘要 本周主要的学习内容是GFPGAN模型。GFPGAN是一种基于生成对抗网络(GAN)的模型&#xff0c;其利用封装在预训练的人脸GAN中的丰富多样的先验进行人脸图像的修复。这种生成面部先验&#xff08;GFP&…...

RestClient

什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端&#xff0c;它允许HTTP与Elasticsearch 集群通信&#xff0c;而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级&#xff…...

[特殊字符] 智能合约中的数据是如何在区块链中保持一致的?

&#x1f9e0; 智能合约中的数据是如何在区块链中保持一致的&#xff1f; 为什么所有区块链节点都能得出相同结果&#xff1f;合约调用这么复杂&#xff0c;状态真能保持一致吗&#xff1f;本篇带你从底层视角理解“状态一致性”的真相。 一、智能合约的数据存储在哪里&#xf…...

地震勘探——干扰波识别、井中地震时距曲线特点

目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波&#xff1a;可以用来解决所提出的地质任务的波&#xff1b;干扰波&#xff1a;所有妨碍辨认、追踪有效波的其他波。 地震勘探中&#xff0c;有效波和干扰波是相对的。例如&#xff0c;在反射波…...

逻辑回归:给不确定性划界的分类大师

想象你是一名医生。面对患者的检查报告&#xff08;肿瘤大小、血液指标&#xff09;&#xff0c;你需要做出一个**决定性判断**&#xff1a;恶性还是良性&#xff1f;这种“非黑即白”的抉择&#xff0c;正是**逻辑回归&#xff08;Logistic Regression&#xff09;** 的战场&a…...

基于uniapp+WebSocket实现聊天对话、消息监听、消息推送、聊天室等功能,多端兼容

基于 ​UniApp + WebSocket​实现多端兼容的实时通讯系统,涵盖WebSocket连接建立、消息收发机制、多端兼容性配置、消息实时监听等功能,适配​微信小程序、H5、Android、iOS等终端 目录 技术选型分析WebSocket协议优势UniApp跨平台特性WebSocket 基础实现连接管理消息收发连接…...

为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?

在建筑行业&#xff0c;项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升&#xff0c;传统的管理模式已经难以满足现代工程的需求。过去&#xff0c;许多企业依赖手工记录、口头沟通和分散的信息管理&#xff0c;导致效率低下、成本失控、风险频发。例如&#…...

工程地质软件市场:发展现状、趋势与策略建议

一、引言 在工程建设领域&#xff0c;准确把握地质条件是确保项目顺利推进和安全运营的关键。工程地质软件作为处理、分析、模拟和展示工程地质数据的重要工具&#xff0c;正发挥着日益重要的作用。它凭借强大的数据处理能力、三维建模功能、空间分析工具和可视化展示手段&…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院查看报告小程序

一、开发环境准备 ​​工具安装​​&#xff1a; 下载安装DevEco Studio 4.0&#xff08;支持HarmonyOS 5&#xff09;配置HarmonyOS SDK 5.0确保Node.js版本≥14 ​​项目初始化​​&#xff1a; ohpm init harmony/hospital-report-app 二、核心功能模块实现 1. 报告列表…...

【RockeMQ】第2节|RocketMQ快速实战以及核⼼概念详解(二)

升级Dledger高可用集群 一、主从架构的不足与Dledger的定位 主从架构缺陷 数据备份依赖Slave节点&#xff0c;但无自动故障转移能力&#xff0c;Master宕机后需人工切换&#xff0c;期间消息可能无法读取。Slave仅存储数据&#xff0c;无法主动升级为Master响应请求&#xff…...

多种风格导航菜单 HTML 实现(附源码)

下面我将为您展示 6 种不同风格的导航菜单实现&#xff0c;每种都包含完整 HTML、CSS 和 JavaScript 代码。 1. 简约水平导航栏 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport&qu…...