Linux内核通用链表 linuxlist.h阅读.pdfVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

Linux内核通用链表linux/list.h阅读

2008-10-2322:43

#ifndef_LINUX_LIST_H

#define_LINUX_LIST_H//宏定义,不做过多解释,就是检查是否包含了

linux/list.h

#ifdef__KERNEL__

#includelinux/stef.h

#includelinux/prefetch.h

#includeasm/system.h

/*

*Thesearenon-NULLpointersthatwillresultinpagefaults

*undernormalcircumstances,usedtoverifythatnobodyuses

*non-initializedlistentries.

*/

这些非空的指针会导致页错误,在正常环境下,用来验证无人使用为初始化的链

表节点,入口.也有解释说能引起中断,或者关于这个地址的处理内核处理的简单,

要么打印日志信息报错,要么直接不处理.

#defineLIST_POISON1((void*)0

#defineLIST_POISON2((void*)0

/*

*Simpledoublylinkedlistimplementation.

*

*Someoftheinternalfunctions(__xxx)areusefulwhen

*manipulatingwholelistsratherthansingleentries,as

*sometimeswealreadyknowthenext/preventriesandwecan

*generatebettercodebyusingthemdirectlyratherthan

*usingthegenericsingle-entryroutines.

*/

entry似乎应该翻译成表或者节点。

简单的双向链表实现:一些内部函数在熟练操作整个链表比单个入口更有用,当

我们已经知道next/prev入口,通过使用直接它们比使用一般的单入口程序产生

更好的代码。

structlist_head{

structlist_head*next,*prev;

};

#defineLIST_HEAD_INIT(name){(name),(name)}

#defineLIST_HEAD(name)\

structlist_headname=LIST_HEAD_INIT(name)

如果一开始没有看懂LIST_HEAD_INIT宏定义的话,上面这个应该可以让人豁然

开朗,初始化一个name链表,让头和尾都指向自己。

#defineINIT_LIST_HEAD(ptr)do{\

(ptr)-next=(ptr);(ptr)-prev=(ptr);\

}while(0)

/*

*Insertanewentrybetweentwoknownconsecutiveentries.

*

*Thisisonlyforinternallistmanipulationwhereweknow

*theprev/nextentriesalready!

*/

在已知的连续节点中间插入一个新的节点

staticinlinevoid__list_a(structlist_head*new,

structlist_head*prev,

structlist_head*next)

{

next-prev=new;

new-next=next;

new-prev=prev;

prev-next=new;

}

/**

*list_a-aanewentry

*@new:newentrytobeae

*@head:listheadtoaitafter

*

*Insertanewentryafterthespecifiedhead.

*Thisisgoodforimplementingstacks.

*/

在制订hea节点之后插入一个新的节点,这个适用于栈

staticinlinevoi

文档评论(0)

134****3224 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档