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

mbed OS双极性步进电机驱动库设计与应用

1. 项目概述BipoarStepperMotor 是一个面向 ARM Cortex-M 系统、专为 mbed OS 平台设计的双极性步进电机驱动库。该库不依赖特定硬件抽象层HAL变体而是基于 mbed OS 提供的标准 DigitalOut 和 PwmOut 接口构建具备良好的跨平台兼容性——可无缝运行于 STM32F4/F7/H7、NXP LPC1768/LPC54608、Renesas RA6M3 等主流 mbed 兼容开发板。其核心目标是以最小的资源开销、最清晰的控制逻辑实现对双极性步进电机Bipolar Stepper Motor的精确相序驱动、速度调节与方向控制。与单极性步进电机不同双极性电机每相绕组仅含两个引出端无中心抽头必须通过 H 桥电路完成电流方向翻转从而实现磁场极性切换。因此BipoarStepperMotor 的设计本质是“相序控制器 H 桥使能协调器”而非简单 GPIO 翻转。它不封装底层 PWM 频率生成或死区时间管理这些由 mbed OS 底层驱动保障而是聚焦于上层运动控制逻辑四拍Full-step、半拍Half-step及微步Microstep模式的时序生成、加减速曲线插值、多电机协同调度等关键环节。该库采用纯 C 编写头文件仅包含mbed.h无第三方依赖所有状态变量均声明为 private 成员对外仅暴露start(),stop(),setSpeed(),rotateSteps()等语义明确的公有接口。其轻量级特性编译后代码体积 2KBRAM 占用 128 字节使其特别适用于资源受限的工业传感器节点、便携式医疗设备执行机构、教育机器人底盘等嵌入式场景。2. 硬件接口与驱动原理2.1 双极性步进电机电气特性标准双极性四线制步进电机如 28BYJ-48 改装版、PH42L020、NEMA17 Bipolar具有两组独立绕组A 相A、A−与 B 相B、B−。其工作依赖于四个离散的电磁状态组合对应定子磁场旋转 90°步序AA−BB−绕组电流流向转子角度增量01001A→A−, B−→B0°10101A−→A, B−→B90°20110A−→A, B→B−90°31010A→A−, B→B−90°注逻辑“1”表示对应 H 桥输出高电平“0”表示低电平实际电流方向由 H 桥上下桥臂导通状态共同决定。2.2 L293D 驱动芯片接口规范BipoarStepperMotor 默认适配 L293D或功能等效的 SN754410、TB6612FNG双 H 桥驱动芯片。L293D 内置两组独立 H 桥每组含 4 个功率 MOSFET支持最大 600mA 持续电流峰值 1.2A工作电压范围 4.5V–36V。其关键引脚定义如下引脚名类型功能说明1A,2A,3A,4A输入逻辑控制信号直接连接 MCU GPIO1Y,2Y,3Y,4Y输出连接电机绕组端子A, A−, B, B−1,2EN,3,4EN使能高电平有效控制对应 H 桥使能状态关键约束条件1,2EN必须同时为高才能启用 A 相 H 桥3,4EN必须同时为高才能启用 B 相 H 桥同一 H 桥内1A与2A不得同时为高避免直通短路实际应用中1A/2A构成 A 相驱动对3A/4A构成 B 相驱动对。2.3 mbed 硬件连接映射在 mbed OS 中需将 L293D 的 6 个控制引脚映射至 MCU 的数字 I/O 口。典型连接方式如下以 NUCLEO-F411RE 为例L293D 引脚mbed Pin Namembed Pin Number说明1AD2PA_2A 相正向驱动2AD3PA_3A 相反向驱动1,2END4PA_4A 相使能PWM 可选3AD5PA_5B 相正向驱动4AD6PA_6B 相反向驱动3,4END7PA_7B 相使能PWM 可选工程实践提示EN引脚若仅作开关使能可接 DigitalOut若需调速通过占空比调节绕组平均电压则必须使用 PwmOut并确保 PWM 频率 20kHz避免人耳可闻噪声。mbed OS 中 PwmOut 默认频率为 20kHz满足绝大多数步进电机需求。3. 核心 API 接口详解BipoarStepperMotor 将全部功能封装于BipolarStepperMotor类中。构造函数完成硬件引脚初始化与内部状态归零后续所有操作均通过成员函数调用实现。3.1 构造函数与初始化BipolarStepperMotor(PinName a_plus, PinName a_minus, PinName b_plus, PinName b_minus, PinName a_en NC, PinName b_en NC);参数名类型说明a_plusPinName连接 L293D1A的 MCU 引脚a_minusPinName连接 L293D2A的 MCU 引脚b_plusPinName连接 L293D3A的 MCU 引脚b_minusPinName连接 L293D4A的 MCU 引脚a_enPinName连接 L293D1,2EN的 MCU 引脚可选默认 NCb_enPinName连接 L293D3,4EN的 MCU 引脚可选默认 NC初始化行为所有DigitalOut引脚默认设为0低电平确保上电瞬间电机静止若a_en或b_en非NC则创建PwmOut对象并设置默认占空比1.0f全使能内部步序计数器current_step初始化为0当前速度current_speed_rpm初始化为0运行状态is_running设为false。3.2 运行控制接口函数签名功能说明典型用法void start(float rpm)启动连续旋转按指定 RPM 运行motor.start(60.0f); // 60 RPMvoid stop(void)立即停止电机保持当前位置非刹车motor.stop();void setSpeed(float rpm)动态调整当前运行速度不影响启停状态motor.setSpeed(30.0f);void rotateSteps(int steps, bool blocking true)精确旋转指定步数正数顺时针负数逆时针motor.rotateSteps(200); // 200 步关键机制说明start()与setSpeed()均调用内部updateTimerInterval()函数根据当前 RPM 计算相邻步序间的毫秒间隔interval_ms公式为interval_ms (60.0f * 1000.0f) / (rpm * steps_per_rev)其中steps_per_rev默认为200可调rotateSteps()在blocking true时使用wait_ms(interval_ms)实现同步阻塞若blocking false则启动内部 Ticker 定时器异步执行此时需确保Ticker对象生命周期长于任务执行时间所有速度变更均平滑过渡无突变冲击。3.3 高级配置接口函数签名功能说明参数范围void setStepsPerRevolution(int steps)设置电机每转步数影响 RPM 计算精度1–10000void setStepMode(StepMode mode)切换驱动模式FULL_STEP,HALF_STEP,MICROSTEP_4枚举值void enableBrakeOnStop(bool enable)停止时是否启用短接制动将 A/A−、B/B− 同时拉高/低true/falsevoid setAcceleration(float rpm_per_sec)设置加速度单位RPM/s用于rotateSteps()的梯形速度规划0.1–1000.0微步模式实现细节MICROSTEP_4模式下单个完整周期需 16 步而非标准 4 步通过在相邻整步间插入中间电流比例点实现库内部维护一个 16 元素的microstep_pattern[]数组存储各微步对应的A,A−,B,B−输出值0 或 1微步驱动显著提升定位精度与运行平稳性但会降低单步扭矩约 30%。4. 典型应用示例解析4.1 基础四拍全步驱动STM32F411RE#include mbed.h #include BipolarStepperMotor.h // 定义 L293D 控制引脚 DigitalOut led(LED1); BipolarStepperMotor motor(D2, D3, D5, D6, D4, D7); // A, A-, B, B-, A_EN, B_EN int main() { motor.setStepsPerRevolution(200); // 200 步/转 motor.setStepMode(BipolarStepperMotor::FULL_STEP); while(1) { motor.start(30.0f); // 30 RPM 顺时针 wait(2.0); // 运行 2 秒 motor.stop(); wait(1.0); motor.start(-30.0f); // -30 RPM 逆时针 wait(2.0); motor.stop(); wait(1.0); } }时序分析30 RPM200 步/转每转耗时60s / 30 2.0s每步耗时2.0s / 200 10ms定时器中断周期10ms四拍循环[1001] → [0101] → [0110] → [1010]4.2 精确定位与加减速FreeRTOS 集成#include mbed.h #include rtos.h #include BipolarStepperMotor.h BipolarStepperMotor motor(D2, D3, D5, D6); Thread motor_task(osPriorityNormal); void motor_control_task(void const *args) { motor.setStepsPerRevolution(400); // 半步模式400 步/转 motor.setAcceleration(100.0f); // 加速 100 RPM/s while(true) { // 从当前位置移动 1000 步顺时针 2.5 圈 motor.rotateSteps(1000, true); ThisThread::sleep_for(1000); // 移动 -500 步逆时针 1.25 圈 motor.rotateSteps(-500, true); ThisThread::sleep_for(1000); } } int main() { motor_task.start(motor_control_task); // 主线程可处理其他任务如串口通信、传感器采集 while(1) { ThisThread::sleep_for(10); } }加减速曲线生成逻辑rotateSteps(1000)触发梯形速度规划库自动计算加速段步数n_acc (v_max^2) / (2 * a)其中v_max为最大允许速度RPMa为设定加速度RPM/s若n_acc total_steps/2则执行“加速-匀速-减速”三段式每一步的延时interval_ms动态更新由updateTimerInterval()实时重载。4.3 多电机协同控制双轴 XY 平台// 控制两个电机分别驱动 X/Y 轴 BipolarStepperMotor motor_x(D2, D3, D5, D6); BipolarStepperMotor motor_y(D8, D9, D10, D11); void move_line(int x_steps, int y_steps) { int max_steps (abs(x_steps) abs(y_steps)) ? abs(x_steps) : abs(y_steps); float x_ratio (float)abs(x_steps) / max_steps; float y_ratio (float)abs(y_steps) / max_steps; for(int i 0; i max_steps; i) { if (i % (int)(1.0f / x_ratio) 0 x_steps ! 0) { motor_x.step(x_steps 0 ? 1 : -1); } if (i % (int)(1.0f / y_ratio) 0 y_steps ! 0) { motor_y.step(y_steps 0 ? 1 : -1); } wait_us(1000); // 1ms 基准步进间隔 } } // 使用示例画一个边长为 100 步的正方形 move_line(100, 0); // X move_line(0, 100); // Y move_line(-100, 0); // X- move_line(0, -100); // Y-5. 关键参数配置与性能调优5.1 速度与分辨率权衡表配置项推荐值工程影响steps_per_rev200全步, 400半步, 16004微步步数越高定位越准但单步扭矩下降最高转速降低pwm_frequency20–50 kHz频率过低10kHz产生啸叫过高100kHz增加开关损耗acceleration50–200 RPM/s加速过快导致失步过慢影响动态响应idle_current_ratio0.3–0.5停止时降低 EN 引脚占空比减少发热与功耗5.2 失步检测与恢复策略扩展建议虽然原库未内置失步检测但可基于 mbed OS 的 QEIQuadrature Encoder Interface模块扩展// 假设电机轴安装 500 线编码器 QEI encoder(D12, D13, NC, 500); // Channel A/B, Index, PPR void check_sync() { static int32_t last_encoder_pos 0; int32_t current_pos encoder.getQuarterCount(); int32_t expected_delta motor.getStepCount() * (500 * 4 / 200); // 每步对应编码器脉冲数 if (abs(current_pos - last_encoder_pos - expected_delta) 10) { // 失步超过 10 个编码器脉冲触发报警或复位 error(Step loss detected!); motor.resetPosition(); } last_encoder_pos current_pos; }5.3 电源与热管理要点L293D 在 12V/500mA 下自身功耗达12V × 0.5A × 0.3 ≈ 1.8W典型压降 1.4V必须加装散热片建议输入电源纹波 100mV否则易引发驱动异常电机绕组电感典型 5–20mH与驱动电压共同决定电流上升时间t_rise ≈ L / R高电压可缩短此时间提升高频响应能力。6. 故障排查与常见问题现象可能原因解决方案电机完全不转①EN引脚未拉高② 电源电压低于 L293D 最小工作电压4.5V③ 绕组断路或接触不良用万用表测EN电平检查电源测量 A/A− 间电阻应为几Ω–几十Ω电机抖动但不连续旋转① 步序逻辑错误如1A/2A同时为高② 供电电流不足L293D 进入限流保护示波器抓取四路控制信号更换更大电流电源或改用 TB6612FNG高速运行失步① 加速度设置过大② 电源内阻过高导致电压跌落③ 未启用微步平滑降低setAcceleration()值加 1000μF 电解电容滤波启用MICROSTEP_4运行中异常停机①Ticker定时器被更高优先级中断抢占② 堆栈溢出尤其 FreeRTOS 下检查中断优先级分组增大任务堆栈osThreadDef(..., osPriorityNormal, 1, 1024)7. 与主流 HAL 库的兼容性说明BipoarStepperMotor 与 STM32 HAL 库共存时需注意以下冲突点GPIO 冲突若 HAL 已初始化某引脚为AF_PP复用推挽则DigitalOut构造失败。解决方案在MX_GPIO_Init()后手动重置引脚模式HAL_GPIO_DeInit(GPIOA, GPIO_PIN_2); // 重置 PA2 __HAL_RCC_GPIOA_CLK_ENABLE(); GPIOA-MODER ~(GPIO_MODER_MODER2); // 清除模式位 GPIOA-MODER | GPIO_MODER_MODER2_0; // 设为输出模式SysTick 冲突mbed OS 与 HAL 均使用 SysTick。推荐完全采用 mbed OS 的Ticker/Timeout禁用 HAL 的HAL_Delay()DMA 冲突若电机控制需配合 ADC 采样应为不同外设分配独立 DMA 通道避免总线争用。该库已在 STM32CubeIDE mbed OS 6.15 环境下完成全功能验证与 HAL 库混合项目中稳定运行超 2000 小时。

相关文章:

mbed OS双极性步进电机驱动库设计与应用

1. 项目概述BipoarStepperMotor 是一个面向 ARM Cortex-M 系统、专为 mbed OS 平台设计的双极性步进电机驱动库。该库不依赖特定硬件抽象层(HAL)变体,而是基于 mbed OS 提供的标准 DigitalOut 和 PwmOut 接口构建,具备良好的跨平台…...

【HALCON实战】set_window_param:解锁图形窗口高级定制与性能调优

1. 为什么你需要掌握set_window_param? 在机器视觉项目开发中,图形窗口就像工程师的眼睛。我见过太多同行把90%的精力花在算法优化上,却忽视了窗口显示这个"最后一公里"问题。直到某次在客户现场演示时,程序因为频繁刷新…...

DanKoe 视频笔记:个人成长:如何变得更加“不同意”(创造一个现实扭曲场)

在本节课中,我们将学习如何通过有意识地坚持自我、明确目标并有效沟通,来构建一个强大的“现实扭曲场”,从而更坚定地追求自己想要的生活,而非被动地迎合他人。 我们常常被教导要友善、随和,避免冲突。然而&#xff0c…...

WebPages 发布

WebPages 发布 引言 随着互联网技术的飞速发展,Web技术已经成为现代信息社会不可或缺的一部分。WebPages作为Web技术的重要应用,旨在为用户提供高效、便捷的网页浏览体验。本文将详细介绍WebPages的发布过程,包括技术选型、功能设计、性能优化以及用户体验等方面。 技术选…...

果实采摘机械手的设计【论文+CAD图纸+Creo三维+外文文献翻译】

果实采摘机械手作为现代农业装备领域的重要创新,其核心作用在于解决传统人工采摘效率低、劳动强度大、成本高等问题。通过机械结构与控制系统的协同设计,该设备可模拟人手抓取动作,精准完成果实识别、定位、采摘及收集全流程,显著…...

AVR机器人固件基座:负熵架构与确定性调度

1. 项目概述“Negentropic Base”是一个面向AVR微控制器平台的嵌入式固件基础框架,专为移动机器人(尤其是轮式探测车、自主巡线小车、轻量级自主导航平台)设计。其名称中的“Negentropic”(负熵)并非玄学术语&#xff…...

Tsunami Arduino硬件抽象库:高精度信号发生与频率测量

1. Tsunami信号发生器与频率计硬件抽象库概述Tsunami 是一款面向嵌入式测试与教学场景的多功能信号发生器与频率计硬件平台,其核心价值在于将高精度模拟信号生成、宽频带数字信号捕获与实时频率测量能力集成于紧凑的单板系统中。本库(tsunami-arduino&am…...

STM32L152C段式LCD驱动库深度解析与移植指南

1. 项目概述LCD_DISCO_L152C是专为 STM32L152C-DISCO 开发板设计的 LCD 驱动库,其核心目标是提供轻量、可靠、可移植的底层显示控制能力。该库并非从零构建,而是基于 ST 官方为 STM32L476VG-DISCO(如 NUCLEO-L476RG 或 DISCOVERY-BOARD-L476V…...

C语言在嵌入式开发中的核心地位与实践技巧

1. 为什么C语言仍然是嵌入式开发的基石?作为一名在嵌入式行业摸爬滚打十年的老工程师,我见过太多人轻视C语言的重要性。直到现在,我面试的应届生中仍有超过60%对指针的理解停留在"变量地址"这种表层概念。但现实是,全球…...

GyverTimers:ATmega硬件定时器寄存器级精准控制

1. GyverTimers 库深度技术解析:面向 ATmega328P 与 ATmega2560 的硬件定时器全功能控制 GyverTimers 是一款专为 AVR 微控制器设计的轻量级、高精度硬件定时器控制库,其核心价值在于 绕过 Arduino 框架的抽象层,直接操作 ATmega 系列 MCU 的…...

别再手动调参了!用GCNet模块给你的ResNet模型一键注入全局感知能力(附PyTorch代码)

全局感知能力升级:用GCNet模块为ResNet模型注入高效注意力机制 在计算机视觉领域,ResNet架构因其出色的性能和稳定性成为众多任务的基准模型。然而,随着注意力机制的兴起,传统卷积神经网络在长距离依赖建模上的局限性逐渐显现。本…...

BM42S3021-1热电偶模块嵌入式驱动与I²C集成实战

1. BM42S3021-1热电偶模块底层技术解析与嵌入式集成实践1.1 模块硬件架构与通信协议本质BM42S3021-1是Best Modules公司推出的高精度热电偶信号调理模块,其核心并非简单的IC从设备,而是一个集成了冷端补偿(Cold Junction Compensation, CJC&a…...

XBeeATCmds库:Arduino嵌入式AT命令封装实践

1. XBeeATCmds 库概述:面向嵌入式开发者的 AT 命令封装实践XBeeATCmds 是一个专为 Arduino 平台设计的轻量级 C 封装库,其核心目标是将 Digi XBee 系列模块(包括 Series 1、Series 2/2B、Series 3 及兼容 Zigbee、802.15.4、DigiMesh 协议的模…...

intv_ai_mk11多场景落地:覆盖内容运营、教育辅助、行政办公等6大方向

intv_ai_mk11多场景落地:覆盖内容运营、教育辅助、行政办公等6大方向 1. 模型介绍与核心能力 intv_ai_mk11是一款基于Llama架构的中等规模文本生成模型,特别适合处理通用问答、文本改写、解释说明和简短创作等任务。这个模型已经完成了本地部署优化&am…...

3个技巧让Blender对齐效率提升10倍:QuickSnap插件全攻略

3个技巧让Blender对齐效率提升10倍:QuickSnap插件全攻略 【免费下载链接】quicksnap Blender addon to quickly snap objects/vertices/points to object origins/vertices/points 项目地址: https://gitcode.com/gh_mirrors/qu/quicksnap 在三维建模的日常工…...

小白友好!MogFace本地部署全攻略,从安装到检测只需3步

小白友好!MogFace本地部署全攻略,从安装到检测只需3步 1. 工具简介 MogFace是一款基于CVPR 2022论文的高精度人脸检测工具,特别适合需要保护隐私的本地化应用场景。它能够准确识别照片中的多个人脸,无论这些人脸是大是小、是正脸…...

7个高效步骤:Meshroom开源三维重建工具从入门到精通

7个高效步骤:Meshroom开源三维重建工具从入门到精通 【免费下载链接】Meshroom 3D Reconstruction Software 项目地址: https://gitcode.com/gh_mirrors/me/Meshroom 技术原理:三维重建的底层逻辑与技术选型 摄影测量技术的数学基础 三维重建技…...

STM32 SRAM调试实战与优化技巧

1. STM32 SRAM调试实战指南在嵌入式开发中,我们通常将程序烧录到Flash中运行。但当你需要快速验证代码、调试硬件问题或进行临时测试时,使用STM32内部SRAM运行程序会是个高效的选择。我最近在调试一个LED控制程序时,就采用了SRAM运行的方式&a…...

PySide6多线程避坑指南:你的‘暂停’和‘停止’真的安全吗?

PySide6多线程避坑指南:你的‘暂停’和‘停止’真的安全吗? 在PySide6的多线程开发中,暂停和停止线程看似简单的操作背后,隐藏着许多开发者容易忽视的陷阱。本文将深入剖析这些潜在问题,并提供经过实战验证的安全解决方…...

弹幕盒子:5分钟掌握专业弹幕制作,零基础也能轻松上手

弹幕盒子:5分钟掌握专业弹幕制作,零基础也能轻松上手 【免费下载链接】danmubox.github.io 弹幕盒子 项目地址: https://gitcode.com/gh_mirrors/da/danmubox.github.io 你是否曾为视频制作寻找合适的弹幕工具而烦恼?想要给视频添加互…...

ABAP - SMW0实现Excel模板下载与数据上传解析全流程指南(附完整代码)

1. 为什么需要Excel模板下载与上传功能 在企业级应用开发中,Excel模板的下载与上传功能几乎是标配。想象一下这样的场景:财务部门需要每月收集各部门的预算数据,如果让每个部门直接在SAP系统里录入,操作复杂且容易出错。而提供一个…...

3步解锁Windows 11 LTSC应用商店:企业版系统的应用生态解决方案

3步解锁Windows 11 LTSC应用商店:企业版系统的应用生态解决方案 【免费下载链接】LTSC-Add-MicrosoftStore Add Windows Store to Windows 11 24H2 LTSC 项目地址: https://gitcode.com/gh_mirrors/ltscad/LTSC-Add-MicrosoftStore 在企业环境中部署的Window…...

告别复杂安装:用快马AI一键生成opencode可运行原型

最近在折腾一个开源项目时,被各种依赖安装和环境配置搞得头大。作为一个经常需要快速验证想法的开发者,我一直在寻找能跳过这些繁琐步骤的工具。直到发现了InsCode(快马)平台,它彻底改变了我的开发流程。 传统安装的痛点 以前要运行一个openc…...

Dramatron:AI驱动的剧本创作革命

Dramatron:AI驱动的剧本创作革命 【免费下载链接】dramatron Dramatron uses large language models to generate coherent scripts and screenplays. 项目地址: https://gitcode.com/gh_mirrors/dr/dramatron 价值定位:重新定义创意写作流程 在…...

AI辅助开发新体验:与快马平台协作迭代,智能生成与优化企业网站代码

AI辅助开发新体验:与快马平台协作迭代,智能生成与优化企业网站代码 最近在帮朋友做一个企业网站项目,尝试了用AI辅助开发的方式,整个过程比想象中顺畅很多。特别是通过InsCode(快马)平台的AI协作功能,从生成初始代码到…...

BEYOND REALITY Z-Image新手入门:三步生成你的第一张8K写真人像

BEYOND REALITY Z-Image新手入门:三步生成你的第一张8K写真人像 1. 为什么选择BEYOND REALITY Z-Image? 在当前的AI图像生成领域,写实人像一直是最具挑战性的任务之一。传统模型往往难以平衡细节精度与自然感,生成的图片要么过于…...

解锁Switch无限可能:TegraRcmGUI图形化注入工具实战指南

解锁Switch无限可能:TegraRcmGUI图形化注入工具实战指南 【免费下载链接】TegraRcmGUI C GUI for TegraRcmSmash (Fuse Gele exploit for Nintendo Switch) 项目地址: https://gitcode.com/gh_mirrors/te/TegraRcmGUI 当你想为Nintendo Switch安装自定义系统…...

STM32水质监测系统开发与物联网应用

1. 项目概述 作为一名嵌入式开发工程师,我最近完成了一个基于STM32的河流水质监测系统项目。这个系统能够实时检测水体的PH值、电导率和浊度等关键参数,并通过物联网技术实现远程监控和自动调节功能。在实际应用中,我发现这套系统特别适合用于…...

COMSOL 6.2有限元仿真模型:“1-3压电复合材料厚度共振模态、阻抗相位曲线、表面位移仿...

COMSOL有限元仿真模型_1-3压电复合材料的厚度共振模态、阻抗相位曲线、表面位移仿真。 材料的几何参数可任意改变 版本为COMSOL6.2,低于此版本会打不开文件 ps:支持超声、光声、压电等相关内容仿真代做搞压电复合材料仿真最头疼的就是参数调麻了——厚度…...

Linux调试信息双输出:script与tee工具详解

1. Linux调试信息双输出方案概述在Linux系统开发过程中,调试信息的输出管理是每个开发者都会遇到的常规需求。默认情况下,使用printf等函数输出的调试信息会直接显示在终端(标准输出stdout)上。但在实际开发场景中,我们…...