一個小的項目,在測試時間和產(chǎn)品量稍微大一些之后,出現(xiàn)了一些莫名其妙的非邏輯錯誤的Bug(最頭疼的是不能每次都能復(fù)制出來)。經(jīng)過修改后,最近一個月的測試都沒有出現(xiàn)。本人在這里得到了原子哥和其他朋友的很多幫助,也把自己的一些經(jīng)驗分享給各位,也歡迎大家指正。
1. 程序偶爾會出現(xiàn)一些Bug,經(jīng)過output串口信息發(fā)現(xiàn)一些堆棧的臨時變量被莫名其妙的修改。
stm32103rbt6的內(nèi)存是20K,算比較小了,看到程序出錯的那個函數(shù)申請了很多零時變量,也需要訪問很多全局變量。猜想是內(nèi)存被其他操作更改所致。
解決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,這個問題就再也沒出現(xiàn)了。
相關(guān)資料:
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. 程序莫名其妙死機,
猜想因為申請了很多零時變量,可能需要調(diào)整Stack_Size
在STM32F10x.s文件中
修改Stack_Size EQU 0x00000200
成Stack_Size EQU 0x00000400
就再沒出現(xiàn)死機的情況。





