文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

鸿蒙内核源码分析(双向链表篇) | 最重要结构体

2024-12-03 12:34

关注

想了解更多内容,请访问:

51CTO和华为官方合作共建的鸿蒙技术社区

https://harmonyos.51cto.com/

鸿蒙内核源码注释中文版 < Gitee仓 | CSDN仓 | Github仓 | Coding仓 >精读内核源码,中文注解分析,深挖地基工程,构建底层网图,四大码仓每日同步更新。

鸿蒙源码分析系列篇 < CSDN | OSCHINA | WeHarmony | 公众号 >问答式导读,生活式比喻,表格化说明,图形化展示,主流站点每日同步更新。

谁是鸿蒙内核最重要的结构体?

答案一定是: LOS_DL_LIST(双向链表),它长这样。

  1. typedef struct LOS_DL_LIST {//双向链表,内核最重要结构体 
  2.     struct LOS_DL_LIST *pstPrev; //前驱节点(左手) 
  3.     struct LOS_DL_LIST *pstNext; //后继节点(右手) 
  4. } LOS_DL_LIST; 

 结构体够简单了吧,只有前后两个指向自己的指针,但恰恰是因为太简单,所以才太不简单. 就像氢原子一样,宇宙中无处不在,占比最高,原因是因为它最简单,最稳定!

内核的各自模块都能看到双向链表的身影,下图是各处初始化双向链表的操作,因为太多了,只截取了部分:


很多人问图怎么来的, source insight 4.0 是阅读大型C/C++工程的必备工具,要用4.0否则中文有乱码。

可以豪不夸张的说理解LOS_DL_LIST及相关函数是读懂鸿蒙内核的关键。前后指针(注者后续将比喻成一对左右触手)灵活的指挥着系统精准的运行,越是深入分析内核源码,越能感受到内核开发者对LOS_DL_LIST非凡的驾驭能力,笔者仿佛看到了无数双手前后相连,拉起了一个个双向循环链表,把指针的高效能运用到了极致,这也许就是编程的艺术吧!这么重要的结构体还是需详细讲解一下。

基本概念

双向链表是指含有往前和往后两个方向的链表,即每个结点中除存放下一个节点指针外,还增加一个指向其前一个节点的指针。其头指针head是唯一确定的。从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结点和后继结点,这种数据结构形式使得双向链表在查找时更加方便,特别是大量数据的遍历。由于双向链表具有对称性,能方便地完成各种插入、删除等操作,但需要注意前后方向的操作。

功能接口

鸿蒙系统中的双向链表模块为用户提供下面几个接口。

请结合下面的代码和图去理解双向链表,不管花多少时间,一定要理解它的插入/删除动作, 否则后续内容将无从谈起.

  1. //将指定节点初始化为双向链表节点 
  2. LITE_OS_SEC_ALW_INLINE STATIC INLINE VOID LOS_ListInit(LOS_DL_LIST *list) 
  3.     list->pstNext = list; 
  4.     list->pstPrev = list; 
  5.  
  6. //将指定节点挂到双向链表头部 
  7. LITE_OS_SEC_ALW_INLINE STATIC INLINE VOID LOS_ListAdd(LOS_DL_LIST *list, LOS_DL_LIST *node) 
  8.     node->pstNext = list->pstNext; 
  9.     node->pstPrev = list; 
  10.     list->pstNext->pstPrev = node; 
  11.     list->pstNext = node; 
  12. //将指定节点从链表中删除,自己把自己摘掉 
  13. LITE_OS_SEC_ALW_INLINE STATIC INLINE VOID LOS_ListDelete(LOS_DL_LIST *node) 
  14.     node->pstNext->pstPrev = node->pstPrev; 
  15.     node->pstPrev->pstNext = node->pstNext; 
  16.     node->pstNext = NULL
  17.     node->pstPrev = NULL

 具体用法

举例 ProcessCB(进程控制块)是描述一个进程的所有信息,其中用到了 8个双向链表,这简直比章鱼还牛逼,章鱼也才四双触手,但进程有8双(16只)触手。

  1. typedef struct ProcessCB { 
  2.     LOS_DL_LIST          pendList;                      //进程所属的阻塞列表,如果因拿锁失败,就由此节点挂到等锁链表上 
  3.     LOS_DL_LIST          childrenList;                  //孩子进程都挂到这里,形成双循环链表 
  4.     LOS_DL_LIST          exitChildList;                 //那些要退出孩子进程挂到这里,白发人送黑发人。 
  5.     LOS_DL_LIST          siblingList;                   //兄弟进程链表, 56个民族是一家,来自同一个父进程. 
  6.     ProcessGroup         *group;                        //所属进程组 
  7.     LOS_DL_LIST          subordinateGroupList;          //进程是组长时,有哪些组员进程 
  8.     UINT32               threadGroupID;                 //哪个线程组是进程的主线程ID 
  9.     UINT32               threadScheduleMap;             //进程的各线程调度位图 
  10.     LOS_DL_LIST          threadSiblingList;            //进程的线程(任务)列表 
  11.     LOS_DL_LIST          threadPriQueueList[OS_PRIORITY_QUEUE_NUM];  //进程的线程组调度优先级哈希表 
  12.     volatile UINT32      threadNumber;  //此进程下的活动线程数 
  13.     UINT32               threadCount;   //在此进程下创建的线程总数 
  14.     LOS_DL_LIST          waitList;     //进程持有等待链表以支持wait/waitpid 
  15. } LosProcessCB; 

 看个简单点的 pendList表示这个进程中所有被阻塞的任务(task)都会挂到这个链表上管理. 任务阻塞的原因很多,可能是申请互斥锁失败,可能等待事件读消息队列,还可能开了一个定时任务等等。

再来看一个复杂点的 threadPriQueueList,这又是干嘛的?从名字可以看出来是线程的队列链表,在鸿蒙内核线程就是任务(task),任务分等了32个优先级,同级的任务放在同一个双向链表中, 32级就是32个双向链表,所以是个链表数组,每条链表中存放的是已就绪等待被调度的任务。

双向链表是内核最重要的结构体,精读内核的路上它会反复的映入你的眼帘,理解它是理解内存运作的关键所在!

作者邮箱:weharmony@126.com

鸿蒙内核源码注释中文版 < Gitee仓 | CSDN仓 | Github仓 | Coding仓 >精读内核源码,中文注解分析,深挖地基工程,构建底层网图,四大码仓每日同步更新

鸿蒙源码分析系列篇 < CSDN | OSCHINA | WeHarmony | 公众号 >问答式导读,生活式比喻,表格化说明,图形化展示,主流站点每日同步更新

©著作权归作者和HarmonyOS技术社区共同所有,如需转载,请注明出处,否则将追究法律责任。

想了解更多内容,请访问:

51CTO和华为官方合作共建的鸿蒙技术社区

https://harmonyos.51cto.com/

 

来源:鸿蒙社区内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯