中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

Linux內(nèi)核設(shè)備驅(qū)動(dòng)之內(nèi)核中鏈表有什么用

小編給大家分享一下Linux內(nèi)核設(shè)備驅(qū)動(dòng)之內(nèi)核中鏈表有什么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都創(chuàng)新互聯(lián)是一家專(zhuān)注于成都做網(wǎng)站、成都網(wǎng)站建設(shè)與策劃設(shè)計(jì),涪城網(wǎng)站建設(shè)哪家好?成都創(chuàng)新互聯(lián)做網(wǎng)站,專(zhuān)注于網(wǎng)站建設(shè)十多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專(zhuān)業(yè)建站公司;建站業(yè)務(wù)涵蓋:涪城等地區(qū)。涪城做網(wǎng)站價(jià)格咨詢(xún):18982081108

/********************
 * 內(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)都可以被稱(chēng)作是鏈表頭。

(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);

以上是“Linux內(nèi)核設(shè)備驅(qū)動(dòng)之內(nèi)核中鏈表有什么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

當(dāng)前名稱(chēng):Linux內(nèi)核設(shè)備驅(qū)動(dòng)之內(nèi)核中鏈表有什么用
URL地址:http://www.rwnh.cn/article34/gshdpe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊(cè)Google、外貿(mào)網(wǎng)站建設(shè)全網(wǎng)營(yíng)銷(xiāo)推廣、外貿(mào)建站面包屑導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司
吴川市| 板桥市| 罗定市| 三明市| 梁山县| 云和县| 罗山县| 隆回县| 文登市| 房山区| 荥阳市| 濮阳市| 阳曲县| 宁津县| 南乐县| 安阳县| 峨边| 惠东县| 柘城县| 察雅县| 武定县| 正定县| 泾源县| 鱼台县| 堆龙德庆县| 宁明县| 金堂县| 九寨沟县| 焉耆| 沂水县| 彭山县| 绵阳市| 霍林郭勒市| 綦江县| 镇巴县| 威海市| 佳木斯市| 柞水县| 白河县| 盐源县| 玛沁县|