ucos源码分析------OSMemCreate()
2013-03-11 16:06
483 查看
最近在看ucos内存管理,整理下学到的东西
OSMemCreate()中红色部分比较难以理解,现分析如下:
1. plink = (void **)addr;
addr强制转换为二位指针:addr作为函数的参数,原本是一位指针,addr指向的是内容,不是一个指针,现在需要将addr的内容变成一个指针,这个指针指向内存分区的块地址,强制转换的目的便在于此,告诉编译器addr指向的不再是内容了,是一个地址,即addr指向的内容变了个名字*plink(里面的数据是不变的)。强制转换的结果给plink用来连接内存分区块。
2. pblk = (INT8U *)addr + blksize;
pblk是一个一个一位指针,指向一个内存分区块,该语句的目的是获取内存分区中第二个块的指针。
3. for循环
for循环的目的是将第一个块地址指向第二个块,第二个指向第三个,以此类推。当然,for循环中未处理最后一个块的连接问题,在接下来的代码中会处理。
INT8U *pblk; void **plink;
plink = (void **)addr; /* Create linked list of free memory blocks */ pblk = (INT8U *)addr + blksize; for (i = 0; i < (nblks - 1); i++) { *plink = (void *)pblk; plink = (void **)pblk; pblk = pblk + blksize; }
OSMemCreate()中红色部分比较难以理解,现分析如下:
1. plink = (void **)addr;
addr强制转换为二位指针:addr作为函数的参数,原本是一位指针,addr指向的是内容,不是一个指针,现在需要将addr的内容变成一个指针,这个指针指向内存分区的块地址,强制转换的目的便在于此,告诉编译器addr指向的不再是内容了,是一个地址,即addr指向的内容变了个名字*plink(里面的数据是不变的)。强制转换的结果给plink用来连接内存分区块。
2. pblk = (INT8U *)addr + blksize;
pblk是一个一个一位指针,指向一个内存分区块,该语句的目的是获取内存分区中第二个块的指针。
3. for循环
for循环的目的是将第一个块地址指向第二个块,第二个指向第三个,以此类推。当然,for循环中未处理最后一个块的连接问题,在接下来的代码中会处理。
相关文章推荐
- ucos源码分析之OSMemCreate()
- ucos源码分析之OSMemCreate()
- ucos 之系统启动 OSStart() 源码分析 3
- ucos中OSMemCreate()函数难点解析
- ucos 最高任务优先级 OS_SchedNew () 最高256个优先级 源码分析
- ucosII OSMemCreate()函数的解析
- ucosII OSMemCreate()函数的解析 .(双指针构成链表)
- UC/OS-II的内存管理OSMemCreate()分析
- HBase createTable 的服务器端实现源码分析
- epoll源码分析---sys_epoll_create()函数
- runc源码分析——create和start
- Raw-OS源码分析之系统初始化
- uC/OS-II源码分析(一)
- uC/OS-II源码分析(总体思路 三)
- ucos sem信号量 源码分析
- Raw-OS源码分析之fsm(有限状态机)
- uC/OS-II源码分析(转载)
- kafka的consumerConnector.createMessageStreams 方法源码分析
- android自带musicplayer源码分析:CreatePlaylist类
- uC/OS-II源码分析(总体思路一)