因为优化等级出现的 莫名其妙的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% 可靠,永远解决

相关推荐
用户805533698032 天前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
荣--5 天前
在 strip 二进制 + 基址随机化的栈里做崩溃去重 —— 三阶段算法与一行 Crash Flag
嵌入式·崩溃分析·栈指纹·去重算法
释然小师弟5 天前
Android开发十年:反思与回顾
android·后端·嵌入式
FreakStudio6 天前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
bush411 天前
嵌入式linux学习记录十四、术语
linux·嵌入式
国产化创客11 天前
ESP32 CameraWebServer 原生摄像头项目全解析
物联网·开源·嵌入式·实时音视频·智能硬件
goldenrolan11 天前
学习型红外控制系统稳定性挂测工装专项总结
软件测试·python·stm32·嵌入式·红外
w4ysonch11 天前
我手搓了一套适用于任何嵌入式项目的跨线程通信API
嵌入式
海砥装备HardAus11 天前
大载重工业无人机动力容错控制:单电机失效下的应急重构算法设计
算法·重构·嵌入式·无人机
济61711 天前
BMS系统专栏:电池状态监控任务
嵌入式硬件·嵌入式·bms电池系统管理