嵌入式自定义通信协议设计与实现指南

news2026/3/23 13:09:29
1. 自定义协议设计原理与工程实践在嵌入式系统开发中通信协议是连接不同功能模块的神经中枢。当标准协议如Modbus、CANopen、HTTP无法满足特定应用场景的轻量化、低开销或业务逻辑耦合需求时自定义协议便成为工程师手中最灵活、最直接的工具。它并非“随意定义”而是基于明确通信目标、受限资源环境和可靠交互原则所构建的一套数据组织与解析规则。本文不讨论抽象概念仅聚焦于实际项目中反复验证有效的自定义协议设计方法论、典型结构范式及关键实现细节。1.1 协议分层的本质物理层与应用层的解耦任何通信链路都天然具备两层属性物理层Physical Layer与应用层Application Layer。这一分层思想源于OSI模型但在嵌入式领域体现得更为朴素与务实。物理层协议定义了数据如何在硬件介质上传输其核心约束由底层接口决定UART单线/双线异步传输依赖波特率、起始位、停止位、校验位等参数同步RS-485差分信号支持多点总线需关注终端电阻、驱动能力、共模电压范围SPI主从同步串行依赖时钟极性CPOL、相位CPHA、片选信号CSI²C二线制同步依赖上拉电阻、时序SCL/SDA建立/保持时间、地址寻址机制。物理层解决的是“能不能传”的问题。只要电平兼容、时序正确、连接无误数据比特流即可被接收端采样到。但此时接收到的仅是一串原始字节无任何语义。应用层协议则定义了这些字节“代表什么、如何解释、怎样响应”。它完全独立于物理层存在。同一RS-485总线可承载Modbus RTU协议用于工业仪表读取也可承载自定义二进制协议用于LED屏控制甚至可承载ASCII文本协议用于调试交互。应用层解决的是“传的是什么、怎么用”的问题。理解这一分层本质至关重要。它意味着更换物理层如将UART升级为LoRa通常只需修改驱动层而无需重写整个业务逻辑反之重构应用层协议如增加字段、变更校验方式也无需改动底层收发函数。这种解耦是嵌入式系统可维护性与可扩展性的基石。1.2 自定义协议的核心设计目标一个成功的自定义协议绝非简单地拼凑几个字节。其设计必须服务于明确的工程目标唯一可识别性Unambiguous Framing接收端必须能精确判断一帧数据的起始与结束位置。在连续字节流中若缺乏可靠的帧界定机制将导致“粘包”或“拆包”错误使后续所有解析失效。这是协议设计的首要任务。数据完整性Integrity Check嵌入式环境普遍存在电磁干扰、电源波动、信号衰减等问题。必须引入校验机制如CRC、XOR、Checksum使接收端能主动发现传输错误并丢弃无效帧避免错误数据污染系统状态。结构可扩展性Extensibility项目需求必然演进。协议设计需预留字段如版本号、保留字节、采用长度字段而非固定格式或使用TLVType-Length-Value结构确保未来新增功能时旧设备能安全忽略未知字段新设备能兼容旧数据。解析高效性Parsing EfficiencyMCU资源Flash、RAM、CPU极其宝贵。协议应便于在资源受限环境下快速解析。例如使用定长字段优于复杂字符串匹配使用二进制编码优于Base64避免深度嵌套的JSON解析除非有专用轻量库。双向交互可靠性Reliable Interaction简单的单向广播无法支撑闭环控制。协议需明确定义请求Request、响应Response、确认ACK、否定确认NACK、心跳Heartbeat等交互模式并规定超时重传、序列号防重放等机制确保指令必达、状态可知。1.3 典型自定义协议结构范式基于上述目标实践中形成数种高度复用的结构范式。以下分析均源自真实项目代码与硬件交互日志非理论推演。1.3.1 ASCII文本协议面向人机交互与调试的清晰范式当通信双方均为MCU与PC上位机且对带宽、实时性要求不高时纯ASCII文本协议因其可读性强、调试便捷、开发门槛低而被广泛采用。其典型结构如下$CMD,PARAM1,PARAM2,PARAM3*XX\r\n$帧头Start Delimiter标识一帧开始。CMD命令标识符Command Identifier如SET设置、GET获取、ALARM报警。PARAMx以英文逗号分隔的参数列表可为数字、字符串或十六进制值。*XX校验字段Checksum此处为$至*前所有字符的ASCII码异或XOR结果以两位十六进制表示。\r\n帧尾End Delimiter回车换行符作为明确的结束标志。工程实例物联网终端与云服务器交互某低功耗NB-IoT终端向云平台上报传感器数据协议定义为$DATA,TEMP25.3,HUMI65.1,BAT3.72,VOLT12.05*4A\r\n解析实现C语言利用sscanf进行结构化解析代码简洁且鲁棒。// 假设 buf 指向接收到的完整字符串如 $DATA,TEMP25.3,HUMI65.1,...*4A\r\n char cmd_str[16]; float temp, humi, bat, volt; uint8_t checksum_received; // 提取校验值最后3位*XX\r if (sscanf(buf strlen(buf) - 5, *%02hhx, checksum_received) ! 1) { return PARSE_ERR_CHECKSUM; } // 计算并验证校验和$ 至 * 前的所有字符 uint8_t calc_checksum 0; for (int i 0; buf[i] ! * buf[i] ! \0; i) { calc_checksum ^ (uint8_t)buf[i]; } if (calc_checksum ! checksum_received) { return PARSE_ERR_CHECKSUM; } // 解析主体数据 if (sscanf(buf, $DATA,TEMP%f,HUMI%f,BAT%f,VOLT%f, temp, humi, bat, volt) ! 4) { return PARSE_ERR_FORMAT; } // 此时 temp, humi, bat, volt 已赋值可直接用于业务逻辑 process_sensor_data(temp, humi, bat, volt);优势sscanf格式化解析极为直观sprintf组包同样简单如sprintf(tx_buf, $ACK,%s*%02X\r\n, cmd_str, calc_checksum)人类可直接通过串口助手观察、构造数据。考量文本编码效率低1字节数字需1-3字节ASCII表示带宽占用高sscanf在极端资源MCU上可能引入较大代码体积需严格防范缓冲区溢出。1.3.2 二进制协议面向控制器间通信的紧凑范式当通信发生在两个MCU之间如主控板与显示板、采集板与网关板且对实时性、带宽、功耗有严苛要求时二进制协议是必然选择。它摒弃可读性换取极致的紧凑性与解析速度。典型结构如下字段长度字节说明帧头2固定值如0xAA 0x55用于快速同步。版本号1协议版本便于未来升级兼容。命令码1标识操作类型如0x01读取状态0x02设置参数0x03报警上报。数据长度1后续数据域的字节数L。数据域L实际有效载荷可为结构体、数组或TLV序列。校验和1对帧头至数据域所有字节进行累加求和或CRC8取低8位。帧尾1固定结束符如0x0DCR增强抗干扰能力。工程实例RS-485总线上的主从控制板通信主控板Master周期性轮询从控板Slave状态从控板上报运行参数与报警信息。从控板发送帧上报AA 55 01 02 03 01 0D │ │ │ │ │ │ │ ├─┴──┴──┴──┴──┴──┴─→ 帧尾 (0x0D) │ │ │ │ │ └────→ 校验和 (0x03 ^ 0x01 0x02, 再0x010x03? 实际为AA550102010x03) │ │ │ │ └───────→ 数据域: 0x01 (报警状态: 1有报警) │ │ │ └──────────→ 数据长度: 0x01 (1字节) │ │ └─────────────→ 命令码: 0x01 (状态上报) │ └────────────────→ 版本号: 0x01 └───────────────────→ 帧头: 0xAA 0x55解析实现C语言基于状态机逐字节处理内存占用极小。typedef struct { uint8_t alarm_status; // 报警状态 uint8_t reserved; // 预留为扩展准备 } __attribute__((packed)) slave_status_t; typedef struct { uint8_t header[2]; // 0xAA, 0x55 uint8_t version; // 协议版本 uint8_t cmd; // 命令码 uint8_t data_len; // 数据长度 uint8_t data[32]; // 数据域最大32字节 uint8_t checksum; // 校验和 uint8_t tail; // 帧尾 0x0D } __attribute__((packed)) rx_frame_t; // 状态机变量 typedef enum { WAIT_START_1, WAIT_START_2, WAIT_VERSION, WAIT_CMD, WAIT_DATA_LEN, WAIT_DATA, WAIT_CHECKSUM, WAIT_TAIL } parse_state_t; parse_state_t state WAIT_START_1; uint8_t rx_buffer[64]; uint8_t rx_index 0; uint8_t expected_data_len 0; void uart_rx_callback(uint8_t byte) { switch(state) { case WAIT_START_1: if (byte 0xAA) state WAIT_START_2; break; case WAIT_START_2: if (byte 0x55) { rx_buffer[0] 0xAA; rx_buffer[1] 0x55; rx_index 2; state WAIT_VERSION; } else { state WAIT_START_1; // 重置 } break; case WAIT_VERSION: rx_buffer[rx_index] byte; state WAIT_CMD; break; case WAIT_CMD: rx_buffer[rx_index] byte; state WAIT_DATA_LEN; break; case WAIT_DATA_LEN: expected_data_len byte; rx_buffer[rx_index] byte; if (expected_data_len 0) { state WAIT_CHECKSUM; } else { state WAIT_DATA; rx_index expected_data_len; // 预留空间 } break; case WAIT_DATA: // 此处应循环接收 expected_data_len 个字节 // 为简化假设已全部收到 state WAIT_CHECKSUM; break; case WAIT_CHECKSUM: rx_buffer[rx_index] byte; state WAIT_TAIL; break; case WAIT_TAIL: if (byte 0x0D) { rx_buffer[rx_index] byte; // 完整帧接收完毕执行校验 if (verify_frame_checksum(rx_buffer, rx_index)) { process_frame(rx_buffer); } } // 无论成功与否重置状态机 state WAIT_START_1; rx_index 0; break; } } // 校验函数计算帧头到校验和前所有字节之和 bool verify_frame_checksum(uint8_t *frame, uint16_t len) { uint8_t calc_sum 0; for (uint16_t i 0; i len - 2; i) { // len-2: 排除最后的 checksum 和 tail calc_sum frame[i]; } return (calc_sum frame[len-2]); } // 处理函数将数据域映射到结构体 void process_frame(uint8_t *frame) { slave_status_t *status (slave_status_t*)frame[5]; // 偏移header(2)ver(1)cmd(1)len(1)5 if (status-alarm_status) { display_alarm_icon(); } }优势单帧最小仅7字节解析为O(1)时间复杂度状态机内存占用恒定天然抗干扰固定帧头。考量调试需借助逻辑分析仪或十六进制串口工具协议变更需同步更新所有节点固件__attribute__((packed))确保结构体无填充字节是跨平台解析的关键。1.3.3 TLVType-Length-Value协议面向复杂数据结构的灵活范式当协议需承载多种异构数据如同时上报温度、湿度、GPS坐标、图片缩略图且各字段出现频率、长度差异巨大时固定格式或简单二进制协议会变得僵化。TLV结构提供了完美的解决方案每个数据项独立编码互不干扰。T (Type)1-2字节唯一标识数据项类型如0x01温度0x02湿度0x03经纬度。L (Length)1-4字节指示后续V字段的字节数。长度字段自身长度需约定如统一用2字节。V (Value)L字节长的实际数据可为任意格式整数、浮点、字符串、二进制块。工程实例Zigbee无线传感网络中的多参数上报采集板通过Zigbee模块将传感器数据发送至显示板。协议定义如下TypeLengthValue (示例)说明0x010x020x00 0xF3(243)温度单位0.1℃0x020x010x41(65)湿度单位%0x030x080x3F 0x80 0x00 0x00 0x40 0x00 0x00 0x00(1.0, 2.0)GPS经度、纬度 (double)0x040x040x00 0x00 0x00 0x01设备ID完整帧为所有TLV项的拼接01 02 00 F3 02 01 41 03 08 3F 80... 04 04 00 00 00 01。解析实现C语言遍历TLV序列动态处理。typedef struct { uint8_t type; uint16_t length; // 简化为2字节长度 uint8_t *value; } tlv_item_t; // 解析函数返回解析出的TLV项数量 uint8_t parse_tlv_stream(uint8_t *stream, uint16_t stream_len, tlv_item_t *items, uint8_t max_items) { uint16_t offset 0; uint8_t count 0; while (offset stream_len count max_items) { if (offset 3 stream_len) break; // 至少需要 T(1)L(2) 字节 tlv_item_t *item items[count]; item-type stream[offset]; item-length (stream[offset] 8) | stream[offset 1]; // Big-Endian offset 2; if (offset item-length stream_len) break; // V长度超出范围 item-value stream[offset]; offset item-length; count; } return count; } // 使用示例 tlv_item_t parsed_items[10]; uint8_t num_items parse_tlv_stream(received_data, data_len, parsed_items, 10); for (uint8_t i 0; i num_items; i) { switch (parsed_items[i].type) { case 0x01: // 温度 int16_t temp_raw (parsed_items[i].value[0] 8) | parsed_items[i].value[1]; float temperature (float)temp_raw / 10.0; update_temperature_display(temperature); break; case 0x02: // 湿度 uint8_t humidity parsed_items[i].value[0]; update_humidity_display(humidity); break; case 0x03: // GPS double *gps (double*)parsed_items[i].value; update_gps_display(gps[0], gps[1]); break; default: // 忽略未知类型保证向前兼容 break; } }优势极致灵活新增字段只需定义新Type旧设备自动跳过天然支持可选字段易于与JSON等高级格式映射。考量解析逻辑稍复杂长度字段本身增加开销需严格约定字节序Big/Little Endian。1.4 关键实现技术从组包到解析的闭环协议的生命力在于两端实现的严格一致性。以下技术是保障这一闭环的核心。1.4.1 组包Packingsprintf与memcpy的抉择ASCII协议sprintf及其变体snprintf是首选。务必使用snprintf并指定缓冲区大小防止溢出。// 安全组包 char tx_buf[128]; int len snprintf(tx_buf, sizeof(tx_buf), $DATA,TEMP%.1f,HUMI%d*%02X\r\n, temp, (int)humi, calc_checksum); if (len 0 || len sizeof(tx_buf)) { // 错误处理缓冲区不足 return ERROR; } uart_send(tx_buf, len);二进制协议memcpy是黄金法则。直接按结构体布局拷贝零开销、零歧义。typedef struct { uint8_t header[2]; uint8_t version; uint8_t cmd; uint8_t data_len; uint8_t data[32]; uint8_t checksum; uint8_t tail; } tx_frame_t; tx_frame_t frame; frame.header[0] 0xAA; frame.header[1] 0x55; frame.version 0x01; frame.cmd 0x01; frame.data_len sizeof(status_data); memcpy(frame.data, status_data, sizeof(status_data)); frame.checksum calculate_checksum((uint8_t*)frame, offsetof(tx_frame_t, checksum)); frame.tail 0x0D; uart_send((uint8_t*)frame, sizeof(frame));1.4.2 解析Parsing状态机与sscanf的协同状态机是解析二进制流的唯一可靠方法。它不依赖缓冲区是否“完整”而是根据当前状态决定下一步动作完美应对UART中断接收的碎片化特性。sscanf是解析ASCII帧的利器但必须配合严格的格式检查与错误分支。永远不要假设sscanf会成功。1.4.3 可靠交互心跳与应答机制心跳包Heartbeat设备定期如30秒发送一个极简帧如$HB*XX\r\n或AA 55 00 00 00证明在线。服务器/主控板若在超时窗口如90秒内未收到则标记设备离线。应答机制ACK/NACK对关键指令如参数设置、固件升级接收方必须返回明确响应。ACK表示成功NACK附带错误码如0x01参数超限0x02存储失败。发送方需实现超时重试建议最多3次。1.5 BOM清单与硬件选型关联性分析协议设计深刻影响硬件选型。一个精心设计的协议能显著降低硬件成本与复杂度。协议特征对硬件的影响典型器件选型考量高带宽需求要求MCU具备高速UART1Mbps、DMA支持或选用SPI/I²C替代。STM32H7系列、ESP32-S3USB CDC强抗干扰需求要求物理层采用RS-485/RS-422需外置隔离芯片如ADM2483、TVS管、终端电阻。ADM2483隔离485、SM712TVS超低功耗需求协议需支持休眠唤醒如LoRaWAN MAC层MCU需具备深度睡眠模式与RTC唤醒。EFM32GG、nRF52840蓝牙5.0 LE安全需求需集成加密协处理器AES或选用带TrustZone的MCU协议层增加签名/加密字段。STM32L5、RT1064带OCOTP加密引擎例如在前述RS-485主从系统中若协议未设计心跳与超时重传一旦从控板因干扰丢失一帧主控板将永远等待系统僵死。此时硬件上再增加看门狗WDT也无法挽救——因为MCU仍在正常运行只是逻辑卡死。协议的健壮性是硬件可靠性的第一道防线。2. 协议文档化从代码注释到正式规范一个未被文档化的协议等于不存在。所有参与开发、测试、维护的工程师都必须基于同一份权威文档工作。文档核心要素协议概览目标、适用场景、物理层描述波特率、接口类型。帧格式详图每个字节的名称、长度、取值范围、默认值、是否可选。命令集每个CMD/Type的完整定义包括请求帧、响应帧、错误码。状态转换图描述设备在不同命令下的状态迁移如“配置模式”、“运行模式”。时序要求最大响应延迟、最小心跳间隔、重试间隔。安全与合规加密算法、密钥管理、EMC/ESD设计要点。文档即代码将协议定义直接嵌入代码生成文档。例如使用Doxygen注释结构体/** * brief RS-485 主从通信协议帧结构 (Version 1.0) * details * 帧格式: [0xAA][0x55][VER][CMD][LEN][DATA...][CHK][0x0D] * - VER: 协议版本当前为 0x01 * - CMD: 命令码见 ref cmd_codes * - LEN: DATA域字节数范围 0-32 * - CHK: 0xAA 至 DATA末尾所有字节的累加和 (8-bit) */ typedef struct { uint8_t header[2]; /// [0] 0xAA, [1] 0x55 uint8_t version; /// 协议版本 uint8_t cmd; /// 命令码 uint8_t data_len; /// 数据长度 uint8_t data[32]; /// 数据载荷 uint8_t checksum; /// 校验和 uint8_t tail; /// 帧尾 0x0D } __attribute__((packed)) rs485_frame_t; /** * enum cmd_codes * brief 主从通信命令码定义 */ typedef enum { CMD_STATUS_REPORT 0x01, /// 从机上报状态 CMD_PARAM_SET 0x02, /// 主机设置参数 CMD_ACK 0x03, /// 确认响应 CMD_NACK 0x04 /// 否定响应 } cmd_code_t;此注释可被Doxygen工具自动生成HTML/PDF文档确保代码与文档零偏差。3. 调试与验证让协议在真实世界中坚不可摧协议的终极考验不在仿真器而在嘈杂的产线、温湿交变的现场、充满开关噪声的配电柜。必备工具链逻辑分析仪捕获UART/485波形验证起始位、停止位、波特率精度、信号质量。可直接解码UART可视化帧结构。USB转多串口调试器同时监控主、从、上位机三方通信定位是哪一端发错、哪一端收错。自制协议测试脚本Python使用pyserial库自动化发送各种边界条件帧超长、超短、错误校验、非法命令验证设备容错能力。关键验证场景压力测试连续发送1000帧检查是否有丢帧、解析错位。干扰注入在通信线上人为制造毛刺如用镊子短接验证帧头同步与校验机制是否生效。电源扰动在通信过程中快速开关电源检查设备能否从异常状态恢复。长时间运行7x24小时不间断通信监测内存泄漏尤其动态分配TLV、计数器溢出如心跳序列号。一位资深工程师曾分享“我花三天写完一个协议却用三周去调试它。那三周里我真正理解了电磁兼容、时钟抖动、以及为什么一个volatile关键字能救一条命。”——协议是硬件与软件、理论与现实、工程师与物理世界对话的契约。它的每一个字节都必须经得起万次锤炼。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2440464.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…