欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Linux內(nèi)核設(shè)備驅(qū)動(dòng)之內(nèi)核中鏈表的使用筆記整理

 更新時(shí)間:2018年12月17日 11:17:49   作者:Engineer-Bruce_Yang  
今天小編就為大家分享一篇關(guān)于Linux內(nèi)核設(shè)備驅(qū)動(dòng)之內(nèi)核中鏈表的使用筆記整理,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
/********************
 * 內(nèi)核中鏈表的應(yīng)用
 ********************/

(1)介紹

在Linux內(nèi)核中使用了大量的鏈表結(jié)構(gòu)來(lái)組織數(shù)據(jù),包括設(shè)備列表以及各種功能模塊中的數(shù)據(jù)組織。這些鏈表大多采用在include/linux/list.h實(shí)現(xiàn)的一個(gè)相當(dāng)精彩的鏈表數(shù)據(jù)結(jié)構(gòu)。

鏈表數(shù)據(jù)結(jié)構(gòu)的定義很簡(jiǎn)單:

struct list_head {
 struct list_head *next, *prev;
};

list_head結(jié)構(gòu)包含兩個(gè)指向list_head結(jié)構(gòu)的指針prev和next,內(nèi)核的數(shù)據(jù)結(jié)構(gòu)通常組織成雙循環(huán)鏈表。

和以前介紹的雙鏈表結(jié)構(gòu)模型不同,這里的list_head沒(méi)有數(shù)據(jù)域。在Linux內(nèi)核鏈表中,不是在鏈表結(jié)構(gòu)中包含數(shù)據(jù),而是在數(shù)據(jù)結(jié)構(gòu)中包含鏈表節(jié)點(diǎn)。如:

struct my_struct{
 struct list_head list;
 unsigned long dog;
 void *cat;
};

linux中的鏈表沒(méi)有固定的表頭,從任何元素開(kāi)始訪問(wèn)都可以。遍歷鏈表僅僅需要從某個(gè)節(jié)點(diǎn)開(kāi)始,沿指針訪問(wèn)下一個(gè)節(jié)點(diǎn),直到又重新回到最初這個(gè)節(jié)點(diǎn)就可以了。每個(gè)獨(dú)立的節(jié)點(diǎn)都可以被稱作是鏈表頭。

(2)鏈表的初始化

a.靜態(tài)

如果在編譯時(shí)靜態(tài)創(chuàng)建鏈表,并且直接引用它,如下:

struct my_struct mine={
 .lost = LIST_HEAD_INIT(mine.list);
 .dog = 0,
 .cat = NULL
};
//或
static LIST_HEAD(fox);
/*等于struct list_head fox = LIST_HEAD_INIT(fox); */

b.動(dòng)態(tài)

struct my_struct *p;
p = kmalloc(GFP_KERNEL, sizeof(my_struct));
p->dog = 0;
p->cat = NULL;
INIT_LIST_HEAD(&p->list);

(3)操作鏈表

內(nèi)核提供了一組函數(shù)來(lái)操作鏈表。

注意!這些函數(shù)都使用一個(gè)或多個(gè)list_head結(jié)構(gòu)體指針作參數(shù)。定義在<linux/list.h>

a.增加節(jié)點(diǎn)

list_add(struct list_head *new, 
     struct list_head *head);
//向指定鏈表的head節(jié)點(diǎn)后面插入new節(jié)點(diǎn)

b.把節(jié)點(diǎn)增加到鏈表尾

list_add_tail(struct list_head *new, 
     struct list_head *head);
//向指定鏈表的head節(jié)點(diǎn)前面插入new節(jié)點(diǎn)

c.從鏈表刪除一個(gè)節(jié)點(diǎn)

list_del(struct list_head *entry);
//將entry從鏈表中移走

d.把節(jié)點(diǎn)從一個(gè)鏈表移到另一個(gè)鏈表

list_move(struct list_head *list, 
     struct list_head *head);

從一個(gè)鏈表中摘除list項(xiàng),然后將其插入head的后面

e.list_empty(struct list_head *head);

鏈表為空返回非0值,否則返回0

f.合并鏈表

list_splice(struct list_head *list, 
      struct list_head *head);
//注意!新的鏈表不包括list節(jié)點(diǎn)

(4)遍歷鏈表

鏈表本身不重要,訪問(wèn)到那個(gè)包含鏈表的結(jié)構(gòu)體才重要

a.從鏈表指針獲得包含該鏈表的結(jié)構(gòu)體的指針

list_entry(struct list_head *ptr,
      type_of_struct, 
      field_name);
  • ptr: list_head指針
  • type_of_struct: 包含ptr的結(jié)構(gòu)體類(lèi)型
  • field_name: 結(jié)構(gòu)體中鏈表字段的名字

如:

my_struct *p = (list_head *ptr, my_struct, list);

b.遍歷鏈表

list_for_each(struct list_head *cursor,
       struct list_head *list);
//常常和list_entry配套使用
//注意!用list_for_each遍歷時(shí),不包括頭節(jié)點(diǎn)

c.遍歷的同時(shí)獲得大結(jié)構(gòu)體指針

list_for_each_entry(type *cursor, 
      struct list_head *list,
      member);

d.遍歷鏈表的同時(shí)釋放每個(gè)被遍歷到的節(jié)點(diǎn)

list_for_each_entry_safe(type *cursor, 
     type *tmp;
     struct list_head *list,
     member);

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

相關(guān)文章

  • Linux命令之mkdir,cat,touch,vi/vim的詳解

    Linux命令之mkdir,cat,touch,vi/vim的詳解

    這篇文章主要介紹了Linux命令之mkdir,cat,touch,vi/vim的內(nèi)容,文章內(nèi)容很詳細(xì),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2023-01-01
  • grub損壞,開(kāi)機(jī)出現(xiàn)GRUB 2 啟動(dòng)提示符的解決方法

    grub損壞,開(kāi)機(jī)出現(xiàn)GRUB 2 啟動(dòng)提示符的解決方法

    下面小編就為大家?guī)?lái)一篇grub損壞,開(kāi)機(jī)出現(xiàn)GRUB 2 啟動(dòng)提示符的解決方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-12-12
  • Linux系統(tǒng)配置靜態(tài)IP地址的詳細(xì)步驟

    Linux系統(tǒng)配置靜態(tài)IP地址的詳細(xì)步驟

    在安裝Linux后,系統(tǒng)的網(wǎng)絡(luò)IP地址默認(rèn)是自動(dòng)分配的,這將導(dǎo)致每次啟動(dòng)Linux系統(tǒng)后,系統(tǒng)的IP地址都會(huì)發(fā)生改變,此文以CentOS7系統(tǒng)環(huán)境為例,詳細(xì)介紹如何配置Linux系統(tǒng)的靜態(tài)IP地址,需要的朋友可以參考下
    2024-04-04
  • CentOS7下 Apache的安裝配置方法

    CentOS7下 Apache的安裝配置方法

    前些天安裝了Nginx,為了好玩我就又安裝Apache,Apache的安裝還算順利。在此做一下學(xué)習(xí)記錄和經(jīng)驗(yàn)分享,需要的朋友可以參考下
    2017-11-11
  • CentOS6.8中/英文環(huán)境切換教程圖解

    CentOS6.8中/英文環(huán)境切換教程圖解

    這篇文章主要介紹了CentOS6.8中/英文環(huán)境切換教程,本文只以中文切換為英文為例給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • Linux系統(tǒng)的修復(fù)模式(單用戶模式)

    Linux系統(tǒng)的修復(fù)模式(單用戶模式)

    大家好,本篇文章主要講的是Linux系統(tǒng)的修復(fù)模式(單用戶模式),感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • 如何在Linux中修改tomcat端口號(hào)

    如何在Linux中修改tomcat端口號(hào)

    這篇文章主要介紹了如何在Linux中修改tomcat端口號(hào),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • 利用Linux防火墻隔離本地欺騙地址的方法詳解

    利用Linux防火墻隔離本地欺騙地址的方法詳解

    防火墻,其實(shí)說(shuō)白了講,就是用于實(shí)現(xiàn)Linux下訪問(wèn)控制的功能的,它分為硬件的或者軟件的防火墻兩種。下面這篇文章主要給大家介紹了關(guān)于如何利用Linux防火墻隔離本地欺騙地址的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考下
    2018-05-05
  • CentOS6.5 升級(jí) Python 2.7 版本詳細(xì)介紹

    CentOS6.5 升級(jí) Python 2.7 版本詳細(xì)介紹

    這篇文章主要介紹了 CentOS6.5 升級(jí) Python 2.7 版本詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下
    2017-01-01
  • Linux下如何創(chuàng)建SFTP賬號(hào)

    Linux下如何創(chuàng)建SFTP賬號(hào)

    這篇文章主要介紹了Linux下如何創(chuàng)建SFTP賬號(hào)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06

最新評(píng)論