KEIL测试malloc

#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开始依次为:静态存储区+栈区

 

看测试地址!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值