一个小的项目,在测试时间和产品量稍微大一些之后,出现了一些莫名其妙的非逻辑错误的Bug(最头疼的是不能每次都能复制出来)。经过修改后,最近一个月的测试都没有出现。本人在这里得到了原子哥和其他朋友的很多帮助,也把自己的一些经验分享给各位,也欢迎大家指正。
1. 程序偶尔会出现一些Bug,经过output串口信息发现一些堆栈的临时变量被莫名其妙的修改。
stm32103rbt6的内存是20K,算比较小了,看到程序出错的那个函数申请了很多零时变量,也需要访问很多全局变量。猜想是内存被其他操作更改所致。
解决ram被使用过多的一个方法是尽量少用全局变量,能用const就用一定用const变量,因为这样会放在flash,而不是ram.
我的程序未将全局变量修改成const变量之前,编译出来
Program Size: Code=40998 RO-data=8702 RW-data=3724 ZI-data=3260
尽量将全局变量修改成const变量之后,编译出来
Program Size: Code=35778 RO-data=13470 RW-data=108 ZI-data=2060
大大减少了RW-data,这个问题就再也没出现了。
相关资料:
Code为程序代码部分
RO-data 表示 程序定义的常量 const temp;
RW-data 表示 已初始化的全局变量
ZI-data 表示 未初始化的全局变量
Total RO Size (Code + RO Data)
Total RW Size (RW Data + ZI Data)
Total ROM Size (Code + RO Data + RW Data)
初始化时RW-data从flash拷贝到RAM
2. 程序莫名其妙死机,
猜想因为申请了很多零时变量,可能需要调整Stack_Size
在STM32F10x.s文件中
修改Stack_Size EQU 0x00000200
成Stack_Size EQU 0x00000400
就再没出现死机的情况。
(6条消息)STM32学习之:RAM的分配和占用_Cheatscat的博客-CSDN博客_stm32 ram
https://blog.csdn.net/Cheatscat/article/details/80194937
程序全局变量莫名其妙被修改:
当查询图片数量时;会导致传感器工作模式:4 ;Modetype_numbe: 2 ;mode8mode: 0里面Modetype_numbe = 0;数值改变;
修改 汉字索引库;将RO Data 由28800改到21612;;程序size由751K改到251K大小
typedef struct
{
FileNameTypeDef PICFile[200];
uint16_t number; //照片数量
}PicNameTypeDef;
将200 改为PICFile[600]后,Modetype_numbe = 2; 程序全局变量不在被改变;
在查询图片数量时,传感器也不在脱机