Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Kernel
第15天:内存池[15天rt-thread入门学习]
发布于 2018-06-04 22:04:53 浏览:2136
订阅该版
* 本帖最后由 wolfgang2018 于 2018-6-4 22:18 编辑 * 15、将本节实例中内存池改为动态申请的方式 我所选择的系统嘀嗒与课程选用的系统嘀嗒有些不一样,实验出来的结果有些不一样:  线程1优先级高,第一阶段是在获取内存池中的内存;  在0~47个内存池申请满后,再使用“rt_mp_alloc”申请时,进入阻塞状态,线程2开始运行;  说明如图  后边依次类推,线程1的2、3次运行都随线程2的释放空间后才能得以运行  后边依次类推,线程1的4、5次运行都随线程2的释放空间后才能得以运行  后边依次类推,线程1的6、7次运行都随线程2的释放空间后才能得以运行  后边依次类推,线程1的8、9次运行都随线程2的释放空间后才能得以运行。 在线程2第1次释放到46、47后,所有48块内存都释放完后,线程2完成第一轮释放。  线程1后在获取完第10次(10次0~47循环判断是否为空指针)内存后,退出循环,剩下的只有线程2在运行。   线程2完成10次释放后,结束了线程的运行。 相关程序代码: ``` //定义48块内存每块内存大小80 #define UPTRLENGTH 48 #define USIZE 80 //内存池内内存块定义为数组 static rt_uint8_t *uptr[UPTRLENGTH]; //内存池地址定义 static struct rt_mempool *user_mp=RT_NULL; //用户线程定义 static rt_thread_t utid1 = RT_NULL; static rt_thread_t utid2 = RT_NULL; //线程1的程序结构,增加了几处内容提示; /***************************************/ static void user_thread1_entry(void *parameter){ rt_uint8_t i, count = 0; rt_uint8_t *block; while(1) { /* 申请内存块 */ rt_kprintf("=============Thread1 Start: %d
",count); for (i = 0; i < UPTRLENGTH; i++){ if (ptr* == RT_NULL){ ptr* = rt_mp_alloc(user_mp, RT_WAITING_FOREVER); rt_kprintf("Thread1: allocate No.%d
", i); } } rt_kprintf("============Thread1: ALL Pool Used!!! %d
", i); /* 继续申请一个内存块,因为已经没有内存块,线程应该被挂起 */ block = rt_mp_alloc(user_mp, RT_WAITING_FOREVER); rt_kprintf("Thread1: Allocate One block mem!
"); /* 释放这个内存块 */ rt_mp_free(block); block = RT_NULL; rt_kprintf("Thread1: Free One block mem!
"); /* 休眠10个OS Tick */ rt_thread_delay(10); /* 循环10次后,退出线程1 */ if (count++ >= 10) { break; } } rt_kprintf("Thread1: End of Thread1! %d
",count); } //线程2的程序结构,增加了几处提示: static void user_thread2_entry(void *parameter){ rt_uint8_t i, count = 0; while (1){ rt_kprintf("===============Thread2 Start: %d
",count); rt_kprintf("Thread2: Begin Try to Release Block!
"); for (i = 0 ; i < UPTRLENGTH; i ++) { /* 释放所有分配成功的内存块 */ if (ptr* != RT_NULL){ rt_kprintf("Thread2 Release Block %d
", i); rt_mp_free(ptr*); ptr* = RT_NULL; } } rt_kprintf("==============Thread2: Free ALL Block! %d
",i); /* 休眠10个OS Tick */ rt_thread_delay(10); /* 循环10次后,退出线程2 */ if (count++ >= 10) { break; } } rt_kprintf("Thread2: End of Thread2!!! %d
",count); } //作业内存池主函数 int user_mempool_sample_init(){ rt_uint8_t i; for (i=0;i
查看更多
0
个回答
默认排序
按发布时间排序
暂无答案,快来添加答案吧
撰写答案
登录
注册新账号
关注者
0
被浏览
2.1k
关于作者
wolfgang2018
这家伙很懒,什么也没写!
提问
16
回答
2
被采纳
0
关注TA
发私信
相关问题
1
请教cpu使用率分析
2
选择FreeRTOS, 还是RT-Thread。
3
thread heap stack overflow ?
4
rtt消息队列delay问题
5
释放被删除线程的内存地方在哪里啊
6
请教:各线程结束后,释放其中的内存的连续性问题
7
STM32F103中断关于信号量、邮箱问题
8
RTT中的线程栈大小如何控制
9
关于线程由执行态变为挂起态的代码实现,,,
10
rt_malloc(rt_size_t size)内存分配函数最小分配尺寸问题
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
6
五分钟玩转RT-Thread新社区
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
使用deepseek协助开发,基于RK3506睿擎派开发板读取传感器数据
2
睿擎工业开发平台---文件系统测试使用
3
睿擎工业开发平台--SPI使用和测四
4
睿擎工业开发平台--can总线使用测试
5
睿擎工业开发平台--如何将i2c1的引脚用于串口4
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
Bootloader
AT
Hardfault
CAN总线
ART-Pi
FinSH
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
FAL
RTC
rt-smart
I2C_IIC
UART
cubemx
ESP8266
BSP
ota在线升级
WIZnet_W5500
PWM
packages_软件包
flash
freemodbus
GD32
潘多拉开发板_Pandora
ADC
keil_MDK
编译报错
定时器
flashDB
ulog
socket
rt_mq_消息队列_msg_queue
msh
中断
Debug
SFUD
C++_cpp
MicroPython
本月问答贡献
出出啊
1524
个答案
343
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
821
个答案
179
次被采纳
crystal266
555
个答案
162
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
2
次点赞
crystal266
2
篇文章
1
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部