专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
关于STM32F103使用MALLOC函数申请动态内存持续写入系统死机问题
2019-07-21 08:20
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
3220
13
1665
本人与使用循环队列对串口接收到的数据进行处理,但是在数据持续入队2300多个字节数据后单片机死了,00字节数据内入队出队均无问题,打印出内存地址也能循环写入,如果把系统堆区大小放大,数据入队能多一些,求大神帮忙。
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
13条回答
冲天菜鸟
2019-07-21 23:31
本帖最后由 冲天菜鸟 于 2017-12-22 09:47 编辑
冲天菜鸟 发表于 2017-12-22 09:45
就是一直用的 ,没释放,就用了一次
申请固定结构体大小
//结构体
typedef struct
{
u8 data[N]; //±£′æ½óêÕμÄêy¾Y
u8 front;
u8 rear;
}sequeue_t;
//申请内存
sequeue_t * create_empty_sequeue()
{
sequeue_t * sq;
//sq = (sequeue_t *)malloc(sizeof(sequeue_t));
sq = mymalloc(sramx,sizeof(sequeue_t));
sq->front = sq->rear = 0;
return sq;
}//判断队列是否空
u8 check_seqeue_empty(sequeue_t * sq)
{
return (sq->front == sq->rear);
}
//入队
u8 enqueue(sequeue_t *sq ,u8 val)
{
sq->rear = (sq->rear+1) % (N-1);
sq->data[sq->rear] = val;
return 0;
}
//出队
u8 dequeue(sequeue_t * sq)
{
u8 val = 0;
sq->front = (sq->front+1) % (N-1);
val = sq->data[sq->front] ;
printf("p| %p ",&(sq->data[sq->front]));
return val;
}
加载中...
查看其它13个回答
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
//结构体
typedef struct
{
u8 data[N]; //±£′æ½óêÕμÄêy¾Y
u8 front;
u8 rear;
}sequeue_t;
//申请内存
sequeue_t * create_empty_sequeue()
{
sequeue_t * sq;
//sq = (sequeue_t *)malloc(sizeof(sequeue_t));
sq = mymalloc(sramx,sizeof(sequeue_t));
sq->front = sq->rear = 0;
return sq;
}//判断队列是否空
u8 check_seqeue_empty(sequeue_t * sq)
{
return (sq->front == sq->rear);
}
//入队
u8 enqueue(sequeue_t *sq ,u8 val)
{
sq->rear = (sq->rear+1) % (N-1);
sq->data[sq->rear] = val;
return 0;
}
//出队
u8 dequeue(sequeue_t * sq)
{
u8 val = 0;
sq->front = (sq->front+1) % (N-1);
val = sq->data[sq->front] ;
printf("p| %p ",&(sq->data[sq->front]));
return val;
}
一周热门 更多>