#include <stdlib.h>
void test_malloc(void)
{
char *p=NULL;
p = (char *)malloc(sizeof(char));
*p =100;
printf("#######*p=%d p=%x#####",*p,p);
free(p);
}
#######*p=100 p=20001f60#####
上次FLASH 的2048 没有static 崩溃 的 故事是 堆栈太小!
https://mp.weixin.qq.com/s/a07UVSY5zprvqB5yylMp_A
其实STM32的堆也是在SRAM的!(个人观点)
栈区:
函数内局部变量的存储单元,函数执行结束时,自动被释放,效率很高,但是分配的内容容量有限。
堆区:
也称动态内存分配。一般由程序员分配和释放,若程序员不释放,程序结束时可能由操作系统回收。
分配方式类似于数据结构中的链表。程序在运行时候调用malloc或者new申请任意大小的内存,程序员自己负责在适当的时候free或者delete释放内存。动态内存的生存期可以由程序决定。良好的使用方法是:如果某动态内存不再使用,需要将其释放掉,否则,很容易出现内存泄漏现象。
其内存的分配规律:
如果系统调用了malloc,从0X20000000开始依次为:静态存储区+堆区+栈区
如果系统未调用了malloc,从0X20000000开始依次为:静态存储区+栈区
看测试地址!!!