在有些情況下,限制你的應(yīng)用程序的因素是 RAM 而不是ROM。在這些情況下,你想要降低對(duì)于全局變量、堆和棧的依賴。這些優(yōu)化由程序員來做比用編譯器來做會(huì)更好。
由于 ROM 通常比RAM 更加便宜(以每字節(jié)為基準(zhǔn)),所以一個(gè)可接受的降低全局?jǐn)?shù)據(jù)量的策略是把常數(shù)移到ROM 中去。如果你用關(guān)鍵字const 聲明所有的常數(shù),那么這可以由編譯器自動(dòng)完成。大部分的C/C++編譯器把所有它們遇到的常全局?jǐn)?shù)據(jù)放入一個(gè)特殊的數(shù)據(jù)段里,這個(gè)數(shù)據(jù)段可以被定位器識(shí)別為可分配ROM 的數(shù)據(jù)段。如果有很多的字符串和導(dǎo)向表數(shù)據(jù)在運(yùn)行的時(shí)候不發(fā)生變化,那么這項(xiàng)技術(shù)是最有價(jià)值的。
如果有些數(shù)據(jù)一旦程序運(yùn)行起來就固定了,但不一定是不變的,那么常數(shù)數(shù)據(jù)段可以改放在一個(gè)tb混合存儲(chǔ)設(shè)備中。然后,這個(gè)存貯設(shè)備可以通過網(wǎng)絡(luò)來更新,或者由一個(gè)指派的技術(shù)員來完成這個(gè)改變。在你的產(chǎn)品要部署的每一個(gè)地區(qū)的稅率就是這種數(shù)據(jù)的一個(gè)例子。如果稅率發(fā)生了改變,那么存儲(chǔ)設(shè)備可以更新,但是同時(shí)也節(jié)省了附加的RAM。
減小棧的大小也可以降低你的程序?qū)τ?RAM 的需要。有一種方法可以準(zhǔn)確地計(jì)算出你需要多大的棧。做法是用一個(gè)特殊的數(shù)據(jù)類型填滿整個(gè)為棧保留的存儲(chǔ)區(qū)域。然后,在軟件運(yùn)行一段時(shí)間之后——最好在正常和緊張兩種情況下都運(yùn)行一下——用調(diào)試工具研究被修改過的棧。有一部分仍然包含有你的特殊類型數(shù)據(jù)的棧存儲(chǔ)區(qū),因此可以安全地從棧的大小中減去那部分存儲(chǔ)區(qū)的大小(注1)。
如果你在使用一個(gè)實(shí)時(shí)的操作系統(tǒng),就要特別當(dāng)心棧的大小。大部分操作系
——————————————————————————————————
注1:當(dāng)然,你可能想在棧中留一點(diǎn)額外的空間——萬一你的測試沒有持續(xù)足夠長的時(shí)間,或者沒有準(zhǔn)確地反映所有可能的運(yùn)行場景。千萬不要忘記棧的溢出對(duì)于你的軟件來說是一個(gè)潛在的致命事件,要不惜一切代價(jià)避免。
統(tǒng)為每一個(gè)任務(wù)創(chuàng)建一個(gè)分離的棧。這些棧用于函數(shù)的調(diào)用以及在一個(gè)任務(wù)的設(shè)備場景中遇到的中斷服務(wù)倒程。你可以通過前面介紹的方式為每一個(gè)任務(wù)的棧決定其數(shù)量。你可以設(shè)法減少任務(wù)的數(shù)量或者切換到一個(gè)操作系統(tǒng),這個(gè)操作系統(tǒng)具有分離的為執(zhí)行所有中斷服務(wù)例程而建立的“中斷棧”。后一種方法可以顯著地降低每個(gè)任務(wù)對(duì)棧大小的要求。
堆的大小受限于 RAM 在所有的全局?jǐn)?shù)據(jù)和棧空間都分配以后剩余的數(shù)量,如果堆太小,你的tbw程序就不能夠在需要的時(shí)候分配內(nèi)存,因此在廢棄它之前一定要把malloc 和new 的結(jié)果和NULL 比較。如果你試過了所有這些建議,而且你的程序仍然需要太多的存儲(chǔ)空間,那么你除了完全刪除所有的堆之外沒有別的選擇。