1.堆和栈大小
- {- c+ Y) ^; I$ @' j: y, O) h# F. G, J6 \: _! H) I, T( f
定义大小在startup_stm32f2xx.s( Q: B4 R1 ^$ I, i" H/ ]; w% l
- Stack_Size EQU 0x00000400, t4 H6 m) ~5 Y, u( {+ I* H
- : ^& a+ |% @- y% H4 K( w$ M
- AREA STACK, NOINIT, READWRITE, ALIGN=3
# T- I9 U7 u0 }- C4 y* ?- p+ T8 d - Stack_Mem SPACE Stack_Size
, ~5 a) o. w$ x% w9 Z - __initial_sp
, {% {5 q; S ?! `2 x& V
9 n# p; u) c+ j: i
9 z/ j2 w# A2 D( |* W6 y- ; <h> Heap Configuration
. a" m* W! |0 m8 h - ; <o> Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
; \+ k8 [6 G" S5 |4 D - ; </h>/ s, a6 X/ y0 H. n
- " W; [9 j$ g" u+ w2 I
- Heap_Size EQU 0x00000200) |+ E' r) d9 h9 m$ e" T# h
0 \( a. x8 P# ?5 w+ X$ i1 {% L- AREA HEAP, NOINIT, READWRITE, ALIGN=3$ m) l: d9 [% u0 t. `" Q
- __heap_base7 ?1 i& ]1 F: w# Z( `
复制代码
8 A9 a" ^, u6 }4 T2.堆和栈位置
# V h. h0 `5 ]- Z* F. ]8 p* C# M% A& L) M v+ P( w
通过MAP文件可知(在目标工程栏-->>双击工程名,就会在keil文件显示框出现map文件)' I" ~: z! i0 T$ Q5 J+ k
- HEAP 0x200106f8 Section 512 startup_stm32f2xx.o(HEAP)( l/ j5 o& ]# S# v! x b0 w
- STACK 0x200108f8 Section 1024 startup_stm32f2xx.o(STACK)
0 y' J' S, c, p2 P8 |+ N4 D - ' ^. f" i1 A3 A! W f0 ^
- __heap_base 0x200106f8 Data 0 startup_stm32f2xx.o(HEAP)
7 V& ~, n. d" n* f1 h( l' X3 ^ - __heap_limit 0x200108f8 Data 0 startup_stm32f2xx.o(HEAP)
- H6 R; T/ H3 f( w2 n' v - __initial_sp 0x20010cf8 Data 0 startup_stm32f2xx.o(STACK)
复制代码 显然 Cortex-m3资料可知:__initial_sp是堆栈指针,它就是FLASH的0x8000000地址前面4个字节(它根据堆栈大小,由编译器自动生成)
; Q# J- B" l, S' l. L
. D6 w2 {7 H! k+ I- x, l) S显然堆和栈是相邻的。
, ~: P5 q `5 u6 u0 O: q- J" h$ U7 j4 x
& B/ t# o$ p4 K0 H! \
" O( n/ O- P0 p/ d% b! V8 f
; C5 M8 h6 Z/ R9 {1 |- w3 z& k
" e6 q1 R' z2 @( J, C- `6 n3.堆和栈空间分配0 k: y% U7 B( P5 t, z& ^( ?- W2 a
1 O! \+ E: Y1 |5 |# K栈:向低地址扩展7 z9 t/ a5 t; G% C. c% n0 J$ E
8 J9 U7 Q# {% v% A9 h堆:向高地址扩展 E+ F" o$ {& T" q: e
+ G5 O7 q0 e/ l6 Q$ G) \
显然如果依次定义变量3 n, t3 G2 l: U# p& [/ @& x
6 R8 a N' H" I0 b先定义的栈变量的内存地址比后定义的栈变量的内存地址要大
0 L) {1 N$ C8 z- O, s; s1 D" Y8 ]3 u1 R5 a+ ^+ W; \# n3 h b& b7 k) K
先定义的堆变量的内存地址比后定义的堆变量的内存地址要小 # x4 J7 ]2 T1 |% @5 n7 ]" V( m# q9 H
. t) w0 u* R: G2 C/ q
4.堆和栈变量5 B% Q1 c0 \' D) s* N$ H
: v+ B5 Z* M7 X# _8 ~0 g) ?! w8 U栈:临时变量,退出该作用域就会自动释放
4 A9 J$ l' d ?" G# Q/ x ~% S6 k- l. s' ?
堆:malloc变量,通过free函数释放- a' P: U5 A# l
* n, W1 k4 v* l2 v9 b+ O
7 q3 a! k3 i/ x: o" F
/ J6 j0 \. }, t; X1 u! x, l另外:堆栈溢出,编译不会提示,需要注意9 F7 X( \9 q1 k' h% _
! X2 p) |% \1 x' W W
2 w$ i# ~. I6 i/ W, a |