因为优化等级出现的 莫名其妙的bug

用宏定义的结构体是【全局变量】

全局变量的【初始化值】存在 FLASH 里

但是 -Oz 最小体积优化下,编译器把 "全 0 初始化" 给优化删除了!

所以变量拿到的还是 RAM 上电脏值!**


1. 先看你这句宏

cpp 复制代码
#define LIB_RingBuffer_EXPORT(x,type,num) \
    type x##Buffer[num]; \
    RingBufferPARM x = { \
        x##Buffer, \
        num, \
        sizeof(type), \
        0, \
        0, \
        0, \
        0, \
    };

调用:

cpp 复制代码
LIB_RingBuffer_EXPORT(gUart2_RX_RingBuffer, uint8_t, 64);

展开后 = 全局结构体变量

cpp 复制代码
uint8_t gUart2_RX_RingBufferBuffer[64];
RingBufferPARM gUart2_RX_RingBuffer = {
    gUart2_RX_RingBufferBuffer,
    64,
    1,
    0,
    0,
    0,
    0,
};

2. 重点来了:编译器 -Oz 做了什么?

** 编译器规则:全局变量如果是【0 + 常量指针】组合

编译器会判定它属于【.bss 段】(需要自动清 0 的段)

但是!

你的结构体里有:指针 + 数字,编译器识别混乱

-Oz 为了减体积,直接【不执行 Flash → RAM 的初始化赋值】!

结果:

cpp 复制代码
msgBuff    = 正常(指针被保留)
maxMsgNum  = 正常
msgSize    = 正常
deIndex    = 随机脏值 ❌
enIndex    = 随机脏值 ❌
deNum      = 随机脏值 ❌
enNum      = 随机脏值 ❌

你写的 {0,0,0,0} 被编译器优化吃了!


3. 为什么 LIB_RingBuffer_Clear() 就一定有效?

因为:

cpp 复制代码
void LIB_RingBuffer_Clear(PRingBufferPARM p)
{
    p->deIndex = 0;
    p->enIndex = 0;
    p->deNum = 0;
    p->enNum = 0;
}

这是运行时指令不是初始化,是运行时赋值! 优化器绝对不敢删!

所以:

  • 初始化宏 = 可能被优化
  • 运行时赋值 = 100% 生效

你写的:

复制代码
RingBufferPARM x = {0,0,0,0};

编译器 -Oz 心里想:

"反正都是 0,我不占 Flash 了,省点空间,让它走.bss 吧"

结果:

没给你赋值成功 → 变量还是脏值!

你手动 Clear()

"我就要在运行时赋值 0,你别管为什么" 编译器老老实实执行 → 正常!


✅ 最终结论(100% 正确)

全局结构体的 {0} 初始化,在 -Oz 优化下不可靠!

必须在【运行时】手动调用一次 Clear () 清零!

这就是为什么:

  • 下载运行正常(调试器会强制清 RAM)
  • 断电重启异常(编译器没给你赋值)
  • 手动 Clear 就 100% 正常

一句话收尾:

不是你写错了,是编译器 -Oz 为了省空间,把你的全局变量初始化 "偷" 了! 运行时手动清零 = 100% 可靠,永远解决

相关推荐
nnnnichijou7 小时前
Qt 6.9 嵌入式 Linux 交叉编译全栈填坑指南(以树莓派5 AArch64 为例
qt·嵌入式·交叉编译·qml·树莓派5
bush41 天前
嵌入式linux学习记录七,中断
linux·嵌入式
都在酒里2 天前
FreeRTOS 综合实战:串口命令控制 LED 闪烁模式与系统监控
stm32·单片机·嵌入式硬件·嵌入式·rtos·嵌入式软件
济6172 天前
ROS2 Humble 开发专栏Ubuntu22.04|基于OpenCV 实现机器视觉人脸检测实验指南
嵌入式硬件·嵌入式·ros2·机器人方向
济6172 天前
【ROS2 Humble 开发专栏】Ubuntu22.04 基于 OpenCV 实现颜色阈值分割与目标坐标定位|附完整工程源码
嵌入式硬件·嵌入式·ros2·机器人开发·机器人方向
2023自学中2 天前
Linux虚拟机,VSCode + GDB 调试配置:launch.json 模板
linux·vscode·嵌入式
2023自学中2 天前
Linux 解压命令速查表
linux·服务器·嵌入式·开发板
lularible2 天前
从沙子到车辙(5.2):实时操作系统
开源·嵌入式·汽车电子
2023自学中2 天前
Linux虚拟机 CMakeLists.txt:x86 与 ARM 双架构编译脚本
linux·c语言·c++·嵌入式
webmote332 天前
从零打造虚拟小智:用浏览器模拟 IoT 设备的实践之路
aigc·.net·嵌入式