當(dāng)前位置:首頁 > 公眾號(hào)精選 > TopSemic嵌入式
[導(dǎo)讀]可能很多人心中都有一個(gè)武俠夢,記得小時(shí)候搬個(gè)小凳子,到鄰家院子里蹭電視看,正值金庸先生的射雕英雄傳熱播,一伙人屏息靜氣,全神貫注,隨著郭靖黃蓉出山入海,馳騁大漠。然后覺得自己比憨憨的郭大俠,還是要聰明一點(diǎn)點(diǎn),于是找來布袋子,裝上沙子,苦練武功。如今想來奇怪,怎么單練這鐵掌幫的功夫呢?真是好壞不分,值得檢討。

可能很多人心中都有一個(gè)武俠夢,記得小時(shí)候搬個(gè)小凳子,到鄰家院子里蹭電視看,正值金庸先生的射雕英雄傳熱播,一伙人屏息靜氣,全神貫注,隨著郭靖黃蓉出山入海,馳騁大漠。然后覺得自己比憨憨的郭大俠,還是要聰明一點(diǎn)點(diǎn),于是找來布袋子,裝上沙子,苦練武功。如今想來奇怪,怎么單練這鐵掌幫的功夫呢?真是好壞不分,值得檢討。

此去經(jīng)年,武俠夢碎。沒辦法華山論劍,只能論一下棧了。

  1. 什么是堆棧

我們說堆棧,其實(shí)堆是堆(Heap),棧是棧(Stack)。一般我們寫程序時(shí)不太關(guān)心堆棧,因?yàn)榫幾g器會(huì)幫我們處理。但是還是有必要把它們弄清楚,不然有時(shí)候出了莫名其妙的問題,會(huì)無從下手。比如說堆棧溢出,就好比一個(gè)幽靈,非常難發(fā)現(xiàn)??雌饋硪磺卸纪?,程序編譯運(yùn)行,測試,可能都好好的,直到它突然出現(xiàn),發(fā)出致命一擊,導(dǎo)致系統(tǒng)崩潰。

先看一個(gè)典型的存儲(chǔ)器示意圖,編譯器把RAM劃分為靜態(tài)存儲(chǔ)區(qū),堆區(qū),棧區(qū)。靜態(tài)存儲(chǔ)區(qū)用于存放全局變量,靜態(tài)變量,編譯的時(shí)候它的大小也就確定了;緊挨著的是堆(Heap)區(qū),由程序調(diào)用malloc,free等函數(shù)來分配和釋放;棧區(qū)由編譯器自動(dòng)分配和釋放,用來傳遞參數(shù),存放局部變量等。棧比較特殊,正常情況下,它是后進(jìn)先出的。

棧的使用是從高地址,也就是Top of Stack開始,向下增長。

那為什么要把局部變量分配在棧里呢?因?yàn)閱纹瑱C(jī)訪問棧用的指令,和訪問全局變量區(qū)域用的指令是不一樣的,訪問棧的指令速度更快。再一個(gè)就是這些局部變量,只有所在函數(shù)被調(diào)用的時(shí)候才會(huì)分配,函數(shù)返回時(shí)分配的空間就被收回了,不像全局變量始終占用內(nèi)存。

我們看一個(gè)程序,用到了比較多種類的變量類型。

編譯后的map文件:

我們可以看到全局變量,還有靜態(tài)局部變量都放到了靜態(tài)存儲(chǔ)區(qū)。非靜態(tài)的局部變量在map文件是找不到的。

特別關(guān)注一下P1這個(gè)指針型變量,因?yàn)樗侨肿兞浚宰兞勘旧矸峙湓陟o態(tài)存儲(chǔ)區(qū),但是它指向的用Malloc申請(qǐng)的內(nèi)存,是在堆區(qū)。如下圖:

  1. 堆棧溢出

堆棧溢出,主要是指棧溢出。因?yàn)槲覀冊诙阎?,用malloc, 或new函數(shù)申請(qǐng)內(nèi)存時(shí),如果空間不夠了,函數(shù)會(huì)返回NULL,很清楚它的空間不夠了。而棧由于是函數(shù)調(diào)用時(shí)分配,占用空間大小跟調(diào)用深度有關(guān),編譯器很難確定最大需要多少空間。如果??臻g過小,直接的結(jié)果就是當(dāng)棧增長超過棧底,堆中的數(shù)據(jù),甚至是靜態(tài)存儲(chǔ)區(qū)數(shù)據(jù)被沖掉,導(dǎo)致不可預(yù)知后果。

那怎么避免堆棧溢出,至少知道發(fā)生了堆棧溢出呢?

一個(gè)就是在啟動(dòng)文件里,把堆棧的值盡量改大。編譯的時(shí)候用 –info=stack可以大概看一下,各個(gè)函數(shù)占用棧的大小。

綜合編譯后RAM剩余空間的大大小,可以直接把棧空間放到最大。在下面的源文件中可以直接修改堆和棧的大小。對(duì)于靜態(tài)存儲(chǔ)空間,編譯器會(huì)根據(jù)實(shí)際使用大小進(jìn)行分配,我們不用關(guān)心。

還有一個(gè)方法,在棧底放置特殊字符,然后在程序運(yùn)行過程中,監(jiān)測特殊字符是否被更改,如果被更改,大概率是發(fā)生了棧溢出,此時(shí)可以采取一定的補(bǔ)救措施。如何操作呢?先在啟動(dòng)文件用EXPORT Stack_Mem導(dǎo)出棧底,在主程序定義同名外部函數(shù)extern void Stack_Mem(void); 然后就可以往棧底寫入數(shù)據(jù)了,參見前面的程序。

這種方法的缺點(diǎn)就是,跑飛了的野指針,也可能篡改這一區(qū)域數(shù)據(jù),造成誤判。還有一個(gè)就是,因?yàn)樽鰯?shù)據(jù)比較判斷,要消耗CPU時(shí)間,一般只能周期性檢測,在沒檢測出問題之前,棧溢出有可能已經(jīng)造成程序出問題了。你用過更好的方法嗎?歡迎一起來探討。


本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉