




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第詳解C語言在STM32中的內(nèi)存分配問題printf("CSTACKaddris0x%x\r\n",pbeginstk);
printf("HEAPaddris0x%x\r\n",pbeginheap);
printf("num_byteaddris0x%x\r\n",num_byte);
printf("num_wordaddris0x%x\r\n",num_word);
printf("num_word_constaddris0x%x\r\n",num_word_const);
printf("point_heapaddris0x%x\r\n",point_heap);
printf("point_heapis0x%x\r\n",point_heap);
printf("num_byte_stackaddris0x%x\r\n",num_byte_stack);
printf("num_byte_staticaddris0x%x\r\n",num_byte_static);
}
打印如下
STACKaddris0x20000320
HEAPaddris0x20000720
num_byteaddris0x20000308
num_wordaddris0x2000030c
num_word_constaddris0x8002a44
point_heapaddris0x20000310
point_heapis0x20000728
num_byte_stackaddris0x200006f8
num_byte_staticaddris0x20000318
先說結(jié)論:
num_byte、num_word、num_byte_static和point_heap存儲(chǔ)在內(nèi)部RAM中。
num_byte_stack存貯在棧中。
point_heap申請到的內(nèi)存在堆中。
num_word_const在內(nèi)部flash中。
如果是有同學(xué)對這個(gè)了然于胸,可以出門左轉(zhuǎn)了,如果有些同學(xué)有興趣,可以進(jìn)一步往下看。
02、大小端
因?yàn)楹竺娴膬?nèi)容涉及到大小端問題,這里先說下大小端問題。
大端(Big-endian):數(shù)據(jù)的高位字節(jié)存放在地址的低端低位字節(jié)存放在地址高端;
小端(Little-endian):數(shù)據(jù)的高位字節(jié)存放在地址的高端低位字節(jié)存放在地址低端;
例如:
數(shù)據(jù)0x12345678存儲(chǔ)格式
大端格式
低地址----0x12|0x34|0x56|0x78----高地址
小端格式
低地址----0x78|0x56|0x34|0x12----高地址
其中的地址,一般由編譯器分配,也可在程序中自行指定。從上表中,可以清晰的看到,大小端是以字節(jié)為單位進(jìn)行數(shù)據(jù)儲(chǔ)存的方式。大端通俗的理解就是賦值數(shù)從左自右;小端則是從右自左。
我們常用的X86結(jié)構(gòu)是小端模式,而KEILC51則為大端模式。很多的ARM,DSP都為小端模式,本文使用的平臺STM32F207就是小段模式。
03、逐步分析
如果有同學(xué)對這部分不是很熟悉,建議先看一下我之前的推文《C語言的內(nèi)存分配》,先把C語言的堆棧,內(nèi)存等概念先熟悉下。
先說關(guān)于堆棧的問題,下面代碼可以打印出IAR平臺下STM32的堆棧起始位置。
#pragmasection="CSTACK"
char*pbeginstk=__section_begin("CSTACK");
#pragmasection="HEAP"
char*pbeginheap=__section_begin("HEAP");
打印的結(jié)果如下
STACKaddris0x20000320
HEAPaddris0x20000720
這個(gè)地址是否正確,我們可以在IARdebug時(shí),使用Disassembly窗口查看。
關(guān)于堆棧大小問題,如下
可以查到棧的終止位置是0x20000720,堆的終止位置是0x20000920。注意:這里計(jì)算牽扯到大小端的問題。
通過計(jì)算:
棧的大小=0x20000720-0x20000320=0x400。
堆的大小=0x20000920-0x20000720=0x200。
這和我們在IAR中的堆棧配置是一樣的。
接下來就先說一下分配在內(nèi)存的變量。
通過打印看出,num_byte、num_word、num_byte_static和point_heap并不在堆棧中,它們存儲(chǔ)在內(nèi)部RAM中。
使用Disassembly窗口查看如下
這也驗(yàn)證了static關(guān)鍵字,在修飾函數(shù)內(nèi)的局部變量時(shí),這個(gè)變量將和全局變量一樣存儲(chǔ)在內(nèi)部ram中。
同時(shí)也說明了,STM32內(nèi)部分配內(nèi)存時(shí)候,是先分配全局變量(和static修飾的局部變量),再分配棧,最后再分配堆的。
對于棧的內(nèi)存分配,局部變量,也就是num_byte_stack是存儲(chǔ)在棧的范圍內(nèi)。
num_byte_stackaddris0x200006f8
它的地址空間在棧中。因?yàn)樵诖a中num_byte_stack=0x11;使用Disassembly窗口查看到對應(yīng)的地址數(shù)值是0x11。
關(guān)于棧,再說一句,棧不僅僅保存了局部變量,它會(huì)在函數(shù)切換,中斷發(fā)生時(shí)保存現(xiàn)場,保存ARM內(nèi)核的寄存器,這些不是這篇文章的討論重點(diǎn),這里先挖個(gè)坑,等以后有空再寫篇文章專門說說這個(gè)部分。
堆的問題,簡單來說:malloc申請的內(nèi)存都在堆中。point_heap指針指向的內(nèi)存地址就在堆的范圍內(nèi)。
point_heapis0x20000728
代碼中*point_heap=0x3421;在Disassembly窗口查看到對應(yīng)的地址數(shù)值是0x3421。
最后一個(gè)num_word_const,const修飾的變量是存儲(chǔ)在內(nèi)部flash
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 廣州市安全生產(chǎn)許可證延期
- 咖啡廳員工管理規(guī)范與培訓(xùn)計(jì)劃
- 安全生產(chǎn)15條安全措施
- 漁業(yè)安全生產(chǎn)制度
- BIM數(shù)字孿生集成-第1篇-洞察及研究
- 2018年度安全生產(chǎn)工作總結(jié)
- 安全生產(chǎn)管理的基本原理
- 安全反思心得體會(huì)范文
- 食品安全自查制度表格
- 倉庫保管員安全心得體會(huì)
- 吊頂工程施工培訓(xùn)講義內(nèi)容詳細(xì)
- 天門山污水處理廠二期擴(kuò)建項(xiàng)目環(huán)境影響報(bào)告書
- 婦產(chǎn)科學(xué) 妊娠合并心臟病
- -衛(wèi)生資格-副高-疾病控制-副高-章節(jié)練習(xí)-慢性非傳染性疾病控制-試題(單選題)(共1125題)
- 骨質(zhì)疏松病人的護(hù)理
- 高中英語全國高考考綱詞匯3600匯總
- GB/T 35068-2018油氣管道運(yùn)行規(guī)范
- GB/T 13277.7-2021壓縮空氣第7部分:活性微生物含量測量方法
- 2023年婁底冷水江市廣播電視臺(融媒體中心)招聘筆試模擬試題及答案解析
- 特勞特戰(zhàn)略定位總裁課程課件
- 陳寶光-TTT課程開發(fā)與設(shè)計(jì)(講義)V2.1
評論
0/150
提交評論