当前位置: 首页 > wzjs >正文

水墨风格 网站成人英语培训班哪个机构好

水墨风格 网站,成人英语培训班哪个机构好,英文seo招聘,公众号开发和小程序开发哪个简单文章目录 Linked List 简介Linked List 操作方法链表头结点初始化创建链表节点添加节点到链表中从链表中删除节点从链表中替换节点移动链表中的节点检查链表链表遍历demo 实例 Linked List 简介 链表是一种数据结构,由一系列节点组成,每个节点包含数据部…

文章目录

      • Linked List 简介
      • Linked List 操作方法
        • 链表头结点初始化
        • 创建链表节点
        • 添加节点到链表中
        • 从链表中删除节点
        • 从链表中替换节点
        • 移动链表中的节点
        • 检查链表
        • 链表遍历
        • demo 实例

Linked List 简介

链表是一种数据结构,由一系列节点组成,每个节点包含数据部分和指向下一个节点的指针
链表可以动态增长或者缩小,适合频繁的插入和删除操作,常见的链表类型有单向链表和双向链表

在 linux 内核开发中,开发者无需自己实现链表或者使用第三方库,内核内置了双向链表实现 struct list_head
定义在 linux/list.h

Linked List 操作方法

链表头结点初始化

Linux 内核链表用链表头 list_head 来表示,因为链表初始化其实就是初始化一个链表头节点

LIST_HEAD(demo_list)

LIST_HEAD 宏将创建一个名称为 demo_list 的链表,其实是一个链表头节点,在没有插入如何节点之前,它的首位指针指向自身,也可以认为首尾指针指向自身时链表就是空的

#define LIST_HEAD_INIT(name) {&(name), &(name)};#define LIST_HAED(name) \struct list_head name = LIST_HEAD_INIT(name);
struct list_head {struct list_head *next;struct list_head *prev;
}

注意 LIST_HAED 宏可以用于定义个链表头节点,LIST_HEAD_INIT 只能用于初始化链表头结点

创建链表节点

Linux 内核链表节点也使用 list_head 来表示,通常内嵌在自定义数据结构中:

struct my_node {struct list_head list;int data;
};struct my_node node

链表节点在插入链表之前也需要初始化,使用 INIT_LIST_HEAD

添加节点到链表中

链表有节点初始化后,就可以往链表中添加节点:

static inline void list_add(struct list_head *new, struct list_head *head)
static inline void list_add_tail(struct list_head *new, struct list_head *head)

其中的 head 表示链表头,new 表示要添加的节点,

list_add 将 new 添加到链表头部
list_add_tail 将 new 添加到链表尾部

从链表中删除节点

从链表中删除节点实际上就是修改下一节点及其相邻节点的 prev 和 next 指针指向,并不会释放节点的内存
其中的 list_del_init 删除节点之后还会对该节点重新进行初始化操作

static inline void list_del(struct list_head *entry)
static inline void list_del_init(struct list_head *entry)
从链表中替换节点

和删除节点同理,替换节点也只是修改了 prev 和 next 的指针指向,并且 list_replace_init 还会对替换出来的节点
进行重新的初始化操作

static inline void list_replace(struct list_head *old, struct list_head *new)
static inline void list_replace_init(struct list_head *old, struct list_head *new)
移动链表中的节点

下面的函数中,list 表示要移动的链表,list_move 表示将其移动到链表首部,
list_move_tail 将其移动到链表尾部

static inline void list_move(struct list_head *list, struct list_head *head)
static inline void list_move_tail(struct list_head *list,struct list_head *head)
检查链表

Linux 内核还提供了检查链表的相关函数,例如:

  • list_is_last: 检查节点是否是链表最后一个节点
  • list_empty: 链表是否为空
  • list_is_singular: 链表是否只有一个节点
static inline int list_is_last(const struct list_head *list,const struct list_head *head)
static inline int list_empty(const struct list_head *head)
static inline int list_is_singular(const struct list_head *head)
链表遍历

Linux 提供了一系列函数来遍历和操作链表中的元素:

  • list_entry(ptr, type, member): 通过链表节点的地址获取包含该节点的结构体指针
  • list_for_each(pos, head) : 遍历链表的每个节点
  • list_for_each_entry(pos, head, member) : 遍历链表中的每个结构体实例
  • list_for_each_entry_safe(pos, n, head, member) : 安全的遍历链表中每个结构体实例,可以在遍历过程中安全删除节点
  • list_for_each_prev(pos, head): 逆向遍历链表中的每个节点
  • list_for_each_entry_reverse(pos, head, member): 逆向遍历链表中每个结构体实例
#define list_entry(ptr, type, member) \
container_of(ptr, type, member)#define list_for_each(pos, head) \for (pos = (head)->next; pos != (head); pos = pos->next)#define list_for_each_entry(pos, head, member)				\for (pos = list_first_entry(head, typeof(*pos), member);	\&pos->member != (head);					\pos = list_next_entry(pos, member))#define list_for_each_entry_safe(pos, n, head, member)			\for (pos = list_first_entry(head, typeof(*pos), member),	\n = list_next_entry(pos, member);			\&pos->member != (head); 					\pos = n, n = list_next_entry(n, member))#define list_for_each_prev(pos, head) \for (pos = (head)->prev; pos != (head); pos = pos->prev)#define list_for_each_entry_reverse(pos, head, member)			\for (pos = list_last_entry(head, typeof(*pos), member);		\&pos->member != (head); 					\pos = list_prev_entry(pos, member))

linux linked_list

demo 实例
//static LIST_HEAD(demo_list);
static struct list_head demo_list;static struct demo_linklistnode {char buffer[LINKEDLIST_BUFFER_SIZE];struct list_head list;
};static ssize_t mdrv_read(struct file *file, char __user *buf, size_t size, loff_t *offset) {size_t to_read = min(size, BUFFER_SIZE - (size_t)*offset);if(to_read == 0) {return 0;}printk(KERN_DEBUG "%s: to_read size:%zu .\n", __func__, to_read);if(copy_to_user(buf, device_buffer + *offset, to_read)) {return -EFAULT;}struct demo_linklistnode* tempnode, *nextnode;int i = 0;list_for_each_entry_safe(tempnode, nextnode, &demo_list, list) {printk(KERN_DEBUG "Node[%d] buffer:%s", i, tempnode->buffer);if(list_is_first(&tempnode->list, &demo_list)) {printk(KERN_DEBUG "==> fist node");} else if(list_is_last(&tempnode->list, &demo_list)) {printk(KERN_DEBUG "==> last node");}printk(KERN_DEBUG "\n");i++;}*offset += to_read;return to_read;
}static ssize_t mdrv_write(struct file *file, const char __user *buf, size_t size, loff_t *offset) {size_t to_write = min(size, BUFFER_SIZE - (size_t)*offset);if(to_write == 0) {return -ENOMEM;}printk(KERN_DEBUG "%s: to_write size %zu .\n", __func__, to_write);if(copy_from_user(device_buffer + *offset, buf, to_write)) {return -EFAULT;}struct demo_linklistnode *node = NULL;node = kmalloc(sizeof(struct demo_linklistnode), GFP_KERNEL);if(!node) {printk(KERN_DEBUG "fail to allocate demo_linklistnode buffer\n");return -ENOMEM;}memset(node->buffer, 0, LINKEDLIST_BUFFER_SIZE);memcpy(node->buffer, device_buffer + *offset, to_write);INIT_LIST_HEAD(&node->list);//list_add(&node->list, &demo_list);list_add_tail(&node->list, &demo_list);*offset += to_write;return to_write;
}
http://www.dtcms.com/wzjs/176230.html

相关文章:

  • 二级域名怎么做网站备案程序员培训班要多少钱
  • ae模板免费网站金昌网站seo
  • 政府网站集约化建设的目的品牌宣传有哪些途径
  • 建设高效的政府门户网站长沙网站关键词排名公司
  • 长沙公司做网站找哪个公司好如何设计一个网页
  • b2b批发网站大全品牌策划运营公司
  • 找外包公司做网站的好处和坏处怎么做网络营销推广啊
  • 网站建设插件百度网站提交入口
  • 帝国网站管理系统后台二十条优化疫情措施
  • 石家庄网站制作设计bt种子搜索神器
  • 挂网站需要什么服务器怎么优化关键词
  • 北京建筑信息网关键词排名优化公司
  • 什么网站程序做资料库seo技术培训唐山
  • 重庆网站建设哪家公司那家好免费开发软件制作平台
  • 怎么免费上传网页网站最近发生的热点新闻事件
  • 网站增加域名备案互联网媒体推广
  • 成都优化网站金戈枸橼酸西地那非片
  • 腾讯云学生怎么做网站的sem扫描电镜
  • 公司微网站建设免费数据分析网站
  • 分局网站建设可以营销的十大产品
  • 微商营销技巧重庆放心seo整站优化
  • WordPress修改文章页的url北京seo网络推广
  • wordpress七牛镜像广东seo教程
  • 郑州网站推建设如何能查到百度搜索排名
  • 网站怎样做移动端适配自媒体发布平台
  • 最近国际时事东莞seo网络优化
  • 海外精品网站建设活动宣传推广方案怎么写
  • 网站界面设计形考任务精准营销及推广
  • 河南网站建设公司|河南网站建设价格费用宁波seo关键词培训
  • 北京网站设计的公司价格百度网