詳解C語言在STM32中的內存分配問題_第1頁
詳解C語言在STM32中的內存分配問題_第2頁
詳解C語言在STM32中的內存分配問題_第3頁
詳解C語言在STM32中的內存分配問題_第4頁
詳解C語言在STM32中的內存分配問題_第5頁
已閱讀5頁,還剩1頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

第詳解C語言在STM32中的內存分配問題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

先說結論:

num_byte、num_word、num_byte_static和point_heap存儲在內部RAM中。

num_byte_stack存貯在棧中。

point_heap申請到的內存在堆中。

num_word_const在內部flash中。

如果是有同學對這個了然于胸,可以出門左轉了,如果有些同學有興趣,可以進一步往下看。

02、大小端

因為后面的內容涉及到大小端問題,這里先說下大小端問題。

大端(Big-endian):數(shù)據(jù)的高位字節(jié)存放在地址的低端低位字節(jié)存放在地址高端;

小端(Little-endian):數(shù)據(jù)的高位字節(jié)存放在地址的高端低位字節(jié)存放在地址低端;

例如:

數(shù)據(jù)0x12345678存儲格式

大端格式

低地址----0x12|0x34|0x56|0x78----高地址

小端格式

低地址----0x78|0x56|0x34|0x12----高地址

其中的地址,一般由編譯器分配,也可在程序中自行指定。從上表中,可以清晰的看到,大小端是以字節(jié)為單位進行數(shù)據(jù)儲存的方式。大端通俗的理解就是賦值數(shù)從左自右;小端則是從右自左。

我們常用的X86結構是小端模式,而KEILC51則為大端模式。很多的ARM,DSP都為小端模式,本文使用的平臺STM32F207就是小段模式。

03、逐步分析

如果有同學對這部分不是很熟悉,建議先看一下我之前的推文《C語言的內存分配》,先把C語言的堆棧,內存等概念先熟悉下。

先說關于堆棧的問題,下面代碼可以打印出IAR平臺下STM32的堆棧起始位置。

#pragmasection="CSTACK"

char*pbeginstk=__section_begin("CSTACK");

#pragmasection="HEAP"

char*pbeginheap=__section_begin("HEAP");

打印的結果如下

STACKaddris0x20000320

HEAPaddris0x20000720

這個地址是否正確,我們可以在IARdebug時,使用Disassembly窗口查看。

關于堆棧大小問題,如下

可以查到棧的終止位置是0x20000720,堆的終止位置是0x20000920。注意:這里計算牽扯到大小端的問題。

通過計算:

棧的大小=0x20000720-0x20000320=0x400。

堆的大小=0x20000920-0x20000720=0x200。

這和我們在IAR中的堆棧配置是一樣的。

接下來就先說一下分配在內存的變量。

通過打印看出,num_byte、num_word、num_byte_static和point_heap并不在堆棧中,它們存儲在內部RAM中。

使用Disassembly窗口查看如下

這也驗證了static關鍵字,在修飾函數(shù)內的局部變量時,這個變量將和全局變量一樣存儲在內部ram中。

同時也說明了,STM32內部分配內存時候,是先分配全局變量(和static修飾的局部變量),再分配棧,最后再分配堆的。

對于棧的內存分配,局部變量,也就是num_byte_stack是存儲在棧的范圍內。

num_byte_stackaddris0x200006f8

它的地址空間在棧中。因為在代碼中num_byte_stack=0x11;使用Disassembly窗口查看到對應的地址數(shù)值是0x11。

關于棧,再說一句,棧不僅僅保存了局部變量,它會在函數(shù)切換,中斷發(fā)生時保存現(xiàn)場,保存ARM內核的寄存器,這些不是這篇文章的討論重點,這里先挖個坑,等以后有空再寫篇文章專門說說這個部分。

堆的問題,簡單來說:malloc申請的內存都在堆中。point_heap指針指向的內存地址就在堆的范圍內。

point_heapis0x20000728

代碼中*point_heap=0x3421;在Disassembly窗口查看到對應的地址數(shù)值是0x3421。

最后一個num_word_const,const修飾的變量是存儲在內部flash

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論