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

STM32F103C8T6最小系统板驱动开发:为部署轻量AI模型做准备

STM32F103C8T6最小系统板驱动开发为部署轻量AI模型做准备你是不是也想过能不能让一块小小的、几十块钱的蓝色小板子跑起来AI模型我说的就是那个在电子爱好者圈子里几乎人手一块的“蓝色药丸”——STM32F103C8T6最小系统板。它核心的Cortex-M3处理器主频只有72MHz内存更是只有区区的20KB RAM和64KB Flash听起来和动辄几个G内存的电脑、手机完全不是一个量级。但正是这种极致的资源限制让在上面成功运行一个哪怕是最简单的AI模型都充满了挑战和成就感。这就像是在一台老式收音机上尝试播放高清视频听起来不可能但一旦做成了那种乐趣是无与伦比的。今天这篇内容就是带你迈出这“不可能”任务的第一步为这块小板子打好硬件基础写好最核心的驱动程序。只有底层驱动稳了后续的模型部署、推理优化才能顺利进行。我们的目标很明确手把手带你点亮LED、打通串口通信、读取模拟信号。这些看似基础的操作正是你未来让AI模型在板子上“看”到数据、“说”出结果的基石。准备好了吗我们开始吧。1. 环境准备搭建你的开发舞台工欲善其事必先利其器。在开始写代码之前我们需要把开发环境搭建好。对于STM32开发目前主流且对新手友好的方式是使用STM32CubeIDE它把代码编辑、编译、下载、调试都集成在了一起省去了很多配置的麻烦。1.1 硬件清单确认首先确保你手头有这几样东西STM32F103C8T6最小系统板就是我们的主角通常是一块蓝色的核心板。USB转TTL串口模块比如CH340、CP2102等型号用于程序下载和串口通信。这是连接电脑和板子的桥梁。杜邦线若干公对公、母对母、公对母最好都准备一些用于连接。一台电脑Windows, macOS 或 Linux 系统都可以。1.2 软件安装与配置安装STM32CubeIDE去ST官网下载对应你操作系统的安装包。安装过程基本就是一路“下一步”建议安装路径不要有中文。安装串口驱动将你的USB转TTL模块插上电脑根据模块型号如CH340去网上搜索并安装对应的驱动程序。安装成功后在电脑的设备管理器里能看到一个新的串口比如COM3或/dev/ttyUSB0。1.3 创建你的第一个工程打开STM32CubeIDE跟着下面几步走新建工程点击File - New - STM32 Project。选择芯片在弹出来的芯片选择器里输入“STM32F103C8”然后选中“STM32F103C8Tx”。右侧会显示芯片的引脚图和资源概览确认无误后点击“Next”。命名工程给你的工程起个名字比如Hello_STM32。其他选项保持默认点击“Finish”。进入Pinout视图工程创建完成后会自动打开一个图形化配置界面。在这里你可以用鼠标点击芯片引脚来分配功能非常直观。至此你的舞台就搭好了。接下来我们就要在这个舞台上让芯片的各个部分“动”起来。2. 基础概念认识你的硬件伙伴在动手配置之前花几分钟了解下我们要打交道的几个核心外设理解它们能干什么后面用起来就得心应手了。GPIO (通用输入输出口)这是芯片与外界最简单的交互方式。你可以把它配置成输出模式用来控制LED的亮灭或者配置成输入模式用来读取一个按键是否被按下。它就像芯片伸向外部世界的“手脚”。UART (通用异步收发传输器)这是我们和电脑“对话”的主要渠道。程序运行中的调试信息、传感器读取的数据都可以通过UART发送到电脑的串口助手上显示出来。同样电脑也能通过它给板子发送指令。它是非常重要的调试和通信工具。ADC (模数转换器)现实世界很多信号是连续变化的模拟量比如温度、光照强度、声音。而单片机只认识0和1这样的数字量。ADC的作用就是把模拟信号比如0-3.3V的电压转换成单片机可以处理的数字值比如0-4095。这是让AI模型感知物理世界的关键。理解了这些我们就可以开始具体的配置和编程了。3. 分步实践点亮第一盏灯GPIO输出让我们从一个经典的“Hello World”硬件版开始——点亮一个LED。这能让你立刻获得正反馈确认你的开发环境、下载流程都是通的。3.1 硬件连接找一颗LED和一颗220欧姆左右的限流电阻。将电阻和LED串联然后连接到LED正极长脚 → 通过电阻 → 连接到板子的PA1引脚你可以选其他任意GPIO口。LED负极短脚 → 连接到板子的GND地引脚。3.2 软件配置与代码回到STM32CubeIDE的图形化配置界面。配置引脚在芯片图上找到PA1用鼠标点击它在弹出的菜单中选择GPIO_Output。你会看到引脚变成了绿色。生成代码点击右上角或菜单栏的“GENERATE CODE”按钮。软件会根据你的图形配置自动生成所有底层的初始化代码。编写用户代码生成代码后在左侧工程树里找到并打开Src文件夹下的main.c文件。我们需要在main函数里的while (1)循环中添加控制LED的代码。找到/* USER CODE BEGIN WHILE */和/* USER CODE END WHILE */这对注释它们之间的区域是留给我们写主循环代码的在这里添加while (1) { /* USER CODE END WHILE */ /* USER CODE BEGIN 3 */ // 将PA1引脚设置为高电平LED亮 HAL_GPIO_WritePin(GPIOA, GPIO_PIN_1, GPIO_PIN_SET); HAL_Delay(500); // 延时500毫秒 // 将PA1引脚设置为低电平LED灭 HAL_GPIO_WritePin(GPIOA, GPIO_PIN_1, GPIO_PIN_RESET); HAL_Delay(500); // 延时500毫秒 } /* USER CODE END 3 */这段代码的逻辑很简单点亮LED等半秒熄灭LED再等半秒如此循环LED就会开始闪烁。3.3 编译与下载编译点击工具栏上的小锤子图标或按CtrlB来编译工程。如果一切顺利下方控制台会显示Build Finished没有错误。连接硬件用杜邦线连接USB转TTL模块和最小系统板TTL模块的TX→ 板子的A10(USART1_RX)TTL模块的RX→ 板子的A9(USART1_TX)TTL模块的GND→ 板子的GND同时确保用USB线给最小系统板供电。下载程序在STM32CubeIDE中点击Run - Debug As - STM32 Cortex-M C/C Application。第一次会弹窗询问调试配置通常保持默认使用ST-LINK但我们是串口下载。这里我们需要先配置为串口下载模式。更简单的方式很多最小系统板自带一键下载电路。你只需要在点击IDE的“下载”按钮前按住板子上的“BOOT0”按键不放再按一下“NRST”复位键然后松开“NRST”最后松开“BOOT0”使芯片进入串口下载模式再点击下载即可。具体操作请参照你的板子说明。下载成功后按一下板子的复位键你应该就能看到LED开始规律地闪烁了恭喜你你已经成功迈出了第一步让这块芯片听从了你的指令。4. 打通对话通道串口打印信息UARTLED闪烁告诉我们程序在跑但我们更想知道程序内部发生了什么。串口就是我们的“调试窗口”。我们来配置串口让板子可以向电脑发送文字信息。4.1 硬件连接这一步的硬件连接在下载程序时已经完成了A9,A10无需改动。4.2 软件配置与代码图形化配置在Pinout视图将PA9配置为USART1_TXPA10配置为USART1_RX。点击左侧边栏的“Connectivity” - “USART1”。在中间的模式Mode中选择“Asynchronous”异步通信。下方参数通常保持默认即可波特率115200数据位8停止位1无校验。生成代码再次点击“GENERATE CODE”。此时UART的初始化代码也自动生成了。编写打印代码在main.c文件的开头/* USER CODE BEGIN Includes */后面我们可以包含标准输入输出库以便使用printf函数。/* USER CODE BEGIN Includes */ #include stdio.h /* USER CODE END Includes */然后我们需要重定向printf的输出到串口。在/* USER CODE BEGIN 4 */和/* USER CODE END 4 */之间这个区域通常用于编写用户函数添加以下函数/* USER CODE BEGIN 4 */ // 重写fputc函数将printf链接到串口 int fputc(int ch, FILE *f) { HAL_UART_Transmit(huart1, (uint8_t *)ch, 1, 1000); // 通过UART1发送一个字符 return ch; } /* USER CODE END 4 */最后我们可以在主循环里使用printf了。修改刚才的while(1)循环while (1) { /* USER CODE END WHILE */ /* USER CODE BEGIN 3 */ HAL_GPIO_TogglePin(GPIOA, GPIO_PIN_1); // 翻转PA1引脚状态替代之前的亮/灭设置效果相同但代码更简洁 printf(LED状态已翻转系统运行时间%lu ms\r\n, HAL_GetTick()); // 打印信息 HAL_Delay(1000); // 延时1秒 } /* USER CODE END 3 */4.3 查看结果编译并下载程序到板子。打开电脑上的串口调试助手软件如Putty、SecureCRT或STM32CubeIDE自带的Serial Monitor。选择正确的串口号就是之前设备管理器里看到的那个设置波特率为115200。打开串口按下板子的复位键。你应该能看到串口助手每隔一秒收到一行信息例如“LED状态已翻转系统运行时间1000 ms”。现在你的板子会“说话”了这对于后续调试AI模型推理过程中的中间结果、性能数据至关重要。5. 感知世界读取模拟信号ADCAI模型需要数据输入而在嵌入式世界很多数据来自模拟传感器。让我们学习如何用ADC读取一个可调电阻电位器的电压值。5.1 硬件连接找一个10kΩ的电位器三个引脚分别连接一端 → 板子的3.3V引脚另一端 → 板子的GND引脚中间抽头 → 板子的PA0引脚这是STM32F103C8T6的ADC1通道05.2 软件配置与代码图形化配置将PA0引脚配置为ADC1_IN0。点击左侧边栏的“Analog” - “ADC1”。在右侧将“IN0”通道勾选上。在下方的“Parameter Settings”中可以保持大部分默认。注意“Scan Conversion Mode”选择“Disabled”因为我们只用一个通道“Continuous Conversion Mode”选择“Enabled”使能连续转换。生成代码点击“GENERATE CODE”。编写读取代码首先在main函数开始处/* USER CODE BEGIN 2 */后面启动ADC/* USER CODE BEGIN 2 */ HAL_ADC_Start(hadc1); // 启动ADC转换 /* USER CODE END 2 */然后在主循环中读取ADC值并打印while (1) { /* USER CODE END WHILE */ /* USER CODE BEGIN 3 */ HAL_ADC_PollForConversion(hadc1, 50); // 等待转换完成超时50ms uint32_t adc_value HAL_ADC_GetValue(hadc1); // 获取转换结果 // ADC是12位的所以值范围是0-4095对应电压0-3.3V float voltage (adc_value * 3.3f) / 4095.0f; printf(ADC原始值%lu 电压%.2f V\r\n, adc_value, voltage); HAL_Delay(200); // 延时200毫秒避免打印太快 } /* USER CODE END 3 */5.3 观察模拟世界编译下载程序后打开串口助手。旋转你连接的电位器你会看到输出的电压值在0到3.3V之间变化。这说明你的板子已经具备了“感知”模拟世界的能力。未来这里接上的可以是光照传感器、声音传感器、温度传感器为你的轻量AI模型提供源源不断的输入数据。6. 实用技巧与下一步走到这里你已经成功掌握了STM32F103C8T6最核心的三个外设驱动开发。整个过程我们利用了STM32CubeMX图形化工具和HAL库这大大降低了入门门槛让你能更专注于逻辑本身。几个小建议善用调试除了串口打印STM32CubeIDE内置的调试器非常强大。你可以设置断点单步执行实时查看变量值是查找复杂Bug的利器。代码结构随着功能增多不要把代码都堆在main.c里。尝试将不同功能的代码模块化放在不同的.c和.h文件中。查阅资料ST官方的参考手册和数据手册是终极宝典。HAL库的每个函数在IDE里按住Ctrl键点击函数名通常都能跳转到其定义和注释这是最好的学习材料。那么为轻量AI模型准备的硬件基础已经打好。下一步就是考虑如何将训练好的、经过极致裁剪和量化的模型比如你提到的“万象熔炉·丹青幻境”的极轻量化版本通过C/C代码集成到这个工程里利用这些驱动去获取输入数据执行推理并输出结果。那将是另一个激动人心的挑战但有了今天稳扎稳打的硬件驱动基础你已经拥有了开启那扇门的钥匙。获取更多AI镜像想探索更多AI镜像和应用场景访问 CSDN星图镜像广场提供丰富的预置镜像覆盖大模型推理、图像生成、视频生成、模型微调等多个领域支持一键部署。

相关文章:

STM32F103C8T6最小系统板驱动开发:为部署轻量AI模型做准备

STM32F103C8T6最小系统板驱动开发:为部署轻量AI模型做准备 你是不是也想过,能不能让一块小小的、几十块钱的蓝色小板子跑起来AI模型?我说的就是那个在电子爱好者圈子里几乎人手一块的“蓝色药丸”——STM32F103C8T6最小系统板。它核心的Cort…...

translategemma-4b-it多场景延伸:结合Whisper实现音视频字幕+画面图文翻译

translategemma-4b-it多场景延伸:结合Whisper实现音视频字幕画面图文翻译 1. 引言:从图文翻译到音视频全栈处理 想象一下这个场景:你拿到一段英文技术分享视频,想快速了解内容,但字幕是英文的,画面里偶尔…...

清音听真Qwen3-ASR-1.7B在科研场景应用:学术讲座→参考文献自动提取

清音听真Qwen3-ASR-1.7B在科研场景应用:学术讲座→参考文献自动提取 1. 科研场景的语音识别痛点 学术研究者经常面临这样的困境:参加完一场精彩的学术讲座,收获了大量宝贵信息,但回顾时却发现很多关键内容和参考文献难以准确记录…...

一键下载Markdown:深求·墨鉴完整使用流程演示

一键下载Markdown:深求墨鉴完整使用流程演示 1. 产品介绍与核心价值 深求墨鉴(DeepSeek-OCR-2)是一款融合传统美学与现代AI技术的文档解析工具。不同于传统OCR软件的冰冷界面,它将水墨艺术元素融入交互设计,让文档数…...

Lingbot-Depth-Pretrain-Vitl-14 工业检测应用:零件安装深度合规性检查

Lingbot-Depth-Pretrain-Vitl-14 工业检测应用:零件安装深度合规性检查 在一条繁忙的装配线上,质检员小王正拿着游标卡尺,弯腰检查每一个产品上螺丝的拧入深度。这项工作枯燥、重复,而且人眼判断总有误差,稍不留神就可…...

PROJECT MOGFACE在网络安全领域的应用:模拟攻击与自动化漏洞报告生成

PROJECT MOGFACE在网络安全领域的应用:模拟攻击与自动化漏洞报告生成 最近和几个做安全的朋友聊天,大家普遍有个感觉:活儿越来越多,但人手总是不够。每天面对海量的日志、层出不穷的漏洞公告、还有永远写不完的渗透测试报告&…...

Qwen3-VL-8B保姆级教程:3步搞定图文对话AI,零基础5分钟上手

Qwen3-VL-8B保姆级教程:3步搞定图文对话AI,零基础5分钟上手 你是不是经常遇到这样的场景:看到一张图片,想知道里面有什么内容;收到一张截图,想快速提取里面的文字信息;或者想开发一个能看懂图片…...

Qwen3-14B开源大模型应用:Qwen3-14b_int4_awq构建跨境电商多语言客服系统

Qwen3-14B开源大模型应用:Qwen3-14b_int4_awq构建跨境电商多语言客服系统 1. 技术背景与模型介绍 Qwen3-14b_int4_awq是基于Qwen3-14B大模型的优化版本,采用了int4精度和AWQ(Adaptive Weight Quantization)量化技术。这个版本通…...

Mirage Flow运维指南:Linux系统监控、日志管理与高可用部署

Mirage Flow运维指南:Linux系统监控、日志管理与高可用部署 最近有不少朋友在部署了Mirage Flow模型后,跑来问我:“模型跑起来了,但怎么知道它现在健不健康?万一挂了怎么办?” 这确实是生产环境里最实际的…...

Stable Yogi Leather-Dress-Collection 开发环境配置:从 Anaconda 虚拟环境到项目运行

Stable Yogi Leather-Dress-Collection 开发环境配置:从 Anaconda 虚拟环境到项目运行 最近有不少朋友在尝试运行 Stable Yogi 这类图像生成模型时,遇到了各种依赖包冲突、版本不匹配的麻烦。明明跟着教程一步步走,结果运行时报错&#xff0…...

Ostrakon-VL-8B硬件检测助手:媲美图拉丁吧的AI装机指导

Ostrakon-VL-8B硬件检测助手:媲美图拉丁吧的AI装机指导 每次打开机箱,看着里面密密麻麻的线缆和各式各样的硬件,你是不是也感到一阵头大?想升级电脑,却分不清哪个是显卡、哪个是内存条,更别提判断它们之间…...

解锁产品创新新视角:深入浅出形态分析法

您是否曾经感到思维卡壳,在为新产品或服务构思时,不论如何脑暴,都只能在已有的想法周围打转?在激烈的市场竞争中,仅仅依靠偶尔的灵感闪现往往是不够的。我们需要一种系统化的方法,来有条不紊地探索所有可能…...

产品经理必知:KANO模型,帮你搞懂用户到底想要什么?

做产品,最怕的就是费心费力做出的新功能,用户根本不买账。你是不是也遇到过这种情况:为了上线一个“高大上”的新功能,团队加班加点一个月,结果上线后数据凄凄惨惨?用户嘴上说着“我想要这个”,…...

SiameseUIE完整指南:test.py可扩展性设计——支持批量文本处理改造

SiameseUIE完整指南:test.py可扩展性设计——支持批量文本处理改造 1. 为什么需要改造test.py? SiameseUIE镜像开箱即用,但原始test.py只面向单次验证场景:它内置5个固定测试样例,逐条运行、逐条打印结果&#xff0c…...

把云盘都装进一个篮子里:Openlist 部署详细指南

前言 你有没有遇到过这样的烦恼:手机里装着阿里云盘、百度网盘、夸克,甚至还有自己家里 NAS 上的文件,每次找个东西都要在几个 App 之间来回切换。想搭个简单的分享页面,又觉得搞个专门的网盘系统太重了。 Openlist 就是为了解决…...

《LeetCode 顺序刷题》51 - 60

51、[困难] N 皇后 位运算 哈希表 class Solution { private:bool checkCol[10], checkDig1[20], checkDig2[20];vector<vector<string>> ret;vector<string> path;int num;void dfs(int row) {if (row num) {ret.push_back(path);return;}for (int col …...

Phi-3-vision-128k-instruct部署案例:边缘设备(Jetson Orin)轻量化适配尝试

Phi-3-vision-128k-instruct部署案例&#xff1a;边缘设备&#xff08;Jetson Orin&#xff09;轻量化适配尝试 1. 模型简介 Phi-3-Vision-128K-Instruct 是一款轻量级的多模态模型&#xff0c;属于Phi-3系列的最新成员。这个模型特别适合在边缘计算设备上运行&#xff0c;因…...

Phi-3-vision-128k-instruct部署案例:高校AI实验室多模态教学平台搭建

Phi-3-vision-128k-instruct部署案例&#xff1a;高校AI实验室多模态教学平台搭建 1. 项目背景与模型介绍 Phi-3-Vision-128K-Instruct是微软推出的轻量级多模态模型&#xff0c;专为图文对话场景优化设计。作为Phi-3模型家族成员&#xff0c;它支持长达128K的上下文窗口&…...

蓝桥杯(排序)

下面介绍几种常用的排序方法以P1177模板题为例&#xff08;1&#xff09;插入排序将数组第一个元素化为已排序区间 从第 2 个元素&#xff08;未排序区间第一个&#xff09;开始&#xff0c;逐个取出元素作为待插入元素 将待插入元素与前面已排序区间的元素从后往前作比较若已排…...

计算机毕业设计springboot面向移动端的线上作业系统的设计与实现App 基于Spring Boot的移动端在线作业管理系统的设计与开发 面向移动设备的线上作业系统开发:基于Spring Boot

计算机毕业设计springboot面向移动端的线上作业系统的设计与实现App_t6302 &#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。随着移动互联网的快速发展&#xff0c;传统的教学模式…...

Python全栈入门到实战【基础篇 13】复合数据类型:字典(键值映射)与集合(无序去重)

前言 哈喽各位小伙伴!前面咱们学了字符串、数字这些基础类型,也掌握了列表这种有序序列——但实际开发中,仅靠这些还不够: 想存储“姓名-年龄-手机号”这种“键值对应”的用户信息,用列表只能按位置存([“张三”, 20, “13812345678”]),查手机号要记索引,极不方便;…...

Qwen3-Reranker-0.6B基础教程:1.2GB模型文件完整性校验(sha256)方法

Qwen3-Reranker-0.6B基础教程&#xff1a;1.2GB模型文件完整性校验&#xff08;sha256&#xff09;方法 1. 为什么需要校验模型文件完整性 当你下载Qwen3-Reranker-0.6B这个1.2GB的大文件时&#xff0c;可能会遇到各种问题&#xff1a;网络中断导致下载不完整、存储设备故障造…...

Phi-3-mini-128k-instruct应用场景:为低代码平台注入智能表单生成与校验能力

Phi-3-mini-128k-instruct应用场景&#xff1a;为低代码平台注入智能表单生成与校验能力 你是不是也遇到过这样的场景&#xff1f;公司要上线一个新业务&#xff0c;产品经理火急火燎地跑过来&#xff1a;“快&#xff0c;明天就要一个用户注册表单&#xff0c;字段大概20个&a…...

UI-TARS-desktop行业案例:医疗信息科用Qwen3-Agent自动抓取指南文献、提取适应症、生成摘要表

UI-TARS-desktop行业案例&#xff1a;医疗信息科用Qwen3-Agent自动抓取指南文献、提取适应症、生成摘要表 1. 医疗信息处理的痛点与解决方案 医疗信息科每天需要处理大量的医学文献、临床指南和研究报告。传统的人工处理方式效率低下&#xff0c;容易出现遗漏和错误。医生和研…...

Qwen Pixel Art实战教程:结合Label Studio构建像素艺术数据标注-生成闭环

Qwen Pixel Art实战教程&#xff1a;结合Label Studio构建像素艺术数据标注-生成闭环 1. 引言&#xff1a;从想法到像素的完整旅程 你有没有想过&#xff0c;自己动手创造一套风格统一的像素艺术角色&#xff1f;比如为你的独立游戏设计主角、NPC和怪物&#xff0c;或者为你的…...

Nanbeige4.1-3B多场景落地:开发者写代码、运营写文案、HR写JD的三类Prompt模板

Nanbeige4.1-3B多场景落地&#xff1a;开发者写代码、运营写文案、HR写JD的三类Prompt模板 你是不是也遇到过这样的问题&#xff1a;拿到一个看起来很强大的AI模型&#xff0c;比如这个3B参数的Nanbeige4.1-3B&#xff0c;但真要用起来的时候&#xff0c;却不知道该怎么跟它“…...

LFM2.5-1.2B-Thinking在Ollama中怎么用?图文并茂的零基础操作手册

LFM2.5-1.2B-Thinking在Ollama中怎么用&#xff1f;图文并茂的零基础操作手册 本文面向零基础用户&#xff0c;手把手教你如何在Ollama中使用LFM2.5-1.2B-Thinking模型&#xff0c;无需任何技术背景&#xff0c;跟着做就能快速上手。 1. 认识LFM2.5-1.2B-Thinking模型 LFM2.5-…...

DeepSeek-OCR · 万象识界实战案例:企业合同扫描件自动转Markdown结构化处理

DeepSeek-OCR 万象识界实战案例&#xff1a;企业合同扫描件自动转Markdown结构化处理 你有没有遇到过这样的情况&#xff1f;公司财务部送来一沓合同扫描件&#xff0c;要求你把关键信息整理成电子文档。你打开PDF&#xff0c;看着密密麻麻的文字和表格&#xff0c;心里默默计…...

BERT文本分割-中文-通用领域企业级应用:提升客服对话日志分析结构化水平

BERT文本分割-中文-通用领域企业级应用&#xff1a;提升客服对话日志分析结构化水平 1. 引言&#xff1a;客服对话分析的结构化挑战 在客服行业中&#xff0c;每天都会产生海量的对话记录。这些对话通常以长文本形式存在&#xff0c;缺乏段落分隔和结构信息&#xff0c;给后续…...

SenseVoice-Small ONNX部署案例:电商直播语音→商品卖点自动提取系统

SenseVoice-Small ONNX部署案例&#xff1a;电商直播语音→商品卖点自动提取系统 1. 项目背景与价值 电商直播已经成为现代零售的重要渠道&#xff0c;但海量的直播内容带来了新的挑战。主播在直播中会详细介绍商品特点&#xff0c;但这些宝贵的卖点信息往往随着直播结束而消…...