STM32 KEIL下的堆栈设置问题

刚接手stm32时,你只编写一个
int main()
{
while(1);
}
build://program size: code=340 ro-data=252 rw-data=0 zi-data=1632
编译后,就会发现这么个程序已用了1600多的ram,要是在51单片机上,会心疼死了,这1600多的ram跑哪儿去了,分析map,你会发现是堆和栈占用的
在startup_stm32f10x_md.s文件中,它的前面几行就有以上定义,这下该明白了吧。
stack_size equ 0x00000400
heap_size equ 0x00000200
顺便记号,关注此帖:
以下引用网上资料 理解堆和栈的区别
(1)栈区(stack):由编译器自动分配和释放,存放函数的参数值、局部变量的值等,其操作方式类似
于数据结构中的栈。
(2)堆区(heap):一般由程序员分配和释放,若程序员不释放,程序结束时可能由操作系统回收。分配
方式类似于数据结构中的链表。
(3)全局区(静态区)(static):全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域,未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。程序结束后由系统自动释放。
(4)文字常量区:常量字符串就是存放在这里的。
(5)程序代码区:存放函数体的二进制代码。
例如:
int a=0; //全局初始化区
char *p1; //全局未初始化区
main()
{
int b; //栈
char s[]=abc; //栈
char *p3= 1234567; //在文字常量区
static int c =0 ; //静态初始化区
p1= (char *)malloc(10); //堆区
strcpy(p1,123456); //123456放在常量区
}
所以堆和栈的区别:
stack的空间由操作系统自动分配/释放,heap上的空间手动分配/释放。
stack的空间有限,heap是很大的自由存储区。
程序在编译期和函数分配内存都是在栈上进行,且程序运行中函数调用时参数的传递也是在栈上进行。
stm32单片机中文官网
意法半导体/st/stm

跨国巨头设天大陷阱 中国成LED照明试验田?
MHR010位移传感器基本原理和分类
全球首个区块链机器人攻克“信息孤岛”协同瓶颈
物联网可以解决零售业的哪些痛点
三孔插座的接地线起作用吗
STM32 KEIL下的堆栈设置问题
oppor11发布会浙江卫视直播中:oppor11发布会现场直播视频一起看,oppor11发布会直播在线观看视频
AMD联手ARM计划2013年推出具备TrustZone功能的X86 APU
应用在水浸探测器中的高精度数字电容传感芯片
“新基建”加速智慧矿山时代到来,矿用无人驾驶挑战与机遇并存
分享一下用ST-LINK Utility识别单片机程序是否跑飞
为什么说英特尔®FPGA是实施边缘AI的理想之选?
PLC数采网关如何实现Q系列三菱PLC远程调试及上下载
土壤盐分测定仪的功能特点及技术参数
大多数电信服务提供商对OPNFV加速开源NFV应用的承诺充满信心
光纤收发器的8个故障排查
如何校准DAC以提供14位性能
回顾封装产业的发展历程
泰克OptiMon高级网络优化产品套件再获殊荣
2018年数据管理发展趋势 上云已成为常态