C++之双向链表与哈希链表用法区别实例(二百六十八)

2024-04-06 05:44

本文主要是介绍C++之双向链表与哈希链表用法区别实例(二百六十八),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长!

优质专栏:Audio工程师进阶系列原创干货持续更新中……】🚀
优质专栏:多媒体系统工程师系列原创干货持续更新中……】🚀
优质视频课程:AAOS车载系统+AOSP14系统攻城狮入门实战课原创干货持续更新中……】🚀

人生格言: 人生从来没有捷径,只有行动才是治疗恐惧和懒惰的唯一良药.

更多原创,欢迎关注:Android系统攻城狮

欢迎关注Android系统攻城狮

1.前言

本篇目的:在阅读Linux内核代码时,发现Binder驱动中的双向链表和哈希链表的挺有意思,分享给大家。

2.双向链表与哈希链表介绍

  • 在Android的Binder区域中,双向链表(struct list_head)和哈希链表(struct hlist_node)是两种不同的数据结构,它们在实现中有一些区别和各自的作用。
  • 首先,让我们了解这两种数据结构的基本概念:
  1. 双向链表(struct list_head)

    • 双向链表是一种数据结构,其中每个节点都包含指向前一个节点和后一个节点的指针。这使得在双向链表中,节点可以双向遍历。
    • 在Linux内核中,双向链表是一种常见的数据结构,用于连接内核中的各种对象,例如进程、文件等。
    • 在Binder区域,双向链表常用于维护连接Binder驱动程序的客户端和服务端之间的通信通道。它们可以帮助管理Binder对象的生命周期和通信路线。
  2. 哈希链表(struct hlist_node)

    • 哈希链表是一种特殊的链表结构,它与传统链表不同之处在于,每个节点可能连接到一个链表桶中,而不是简单地按照顺序连接。
    • 在哈希链表中,节点被散列到特定的桶中,以提高检索效率。这使得在大型数据集中查找特定项的时间复杂度得到了显著改善。
    • 在Android的Binder区域,哈希链表通常用于管理Binder节点的分配和释放。通过哈希链表,系统可以更有效地管理Binder对象的分配和回收,以提高性能和资源利用率。

现在来比较双向链表和哈希链表在Binder区域中的作用和区别:

  1. 作用

    • 双向链表用于维护Binder通信通道的连接关系,帮助管理客户端和服务端之间的通信路线。
    • 哈希链表用于管理Binder对象的分配和释放,以提高资源管理的效率和性能。
  2. 区别

    • 双向链表提供了顺序访问节点的能力,而哈希链表则通过散列将节点分布到不同的桶中,提高了查找效率。
    • 双向链表的节点包含指向前一个和后一个节点的指针,而哈希链表的节点可能包含指向桶中下一个节点的指针。
  • 总的来说,在Android的Binder区域中,双向链表和哈希链表都是重要的数据结构,用于管理Binder对象和通信通道,但它们在实现方式和作用上略有不同,以满足不同的需求和优化性能。

Android的Binder驱动数据结构

  • 在Android的Binder驱动数据结构中,struct list_head 表示双向链表,而 struct hlist_head 和 struct hlist_node 表示哈希链表的头部和节点。

  • 1.双向链表 struct list_head

  • 每个 struct list_head 结构包含两个指针,分别指向下一个节点和前一个节点,因此构成了一个双向链表。

  • 用途:双向链表通常用于存储元素的有序集合,并且支持在常量时间内对链表中的元素进行插入、删除和前向/后向遍历。

  • 2.哈希链表 struct hlist_head 和 struct hlist_node

  • struct hlist_head 表示哈希链表的头部,其中包含一个指向链表的第一个节点的指针。

  • struct hlist_node 表示哈希链表中的节点,每个节点包含一个指向下一个节点的指针以及一个指向前一个节点指针的指针。

  • 用途:哈希链表通常用于在哈希表中解决哈希冲突。每个桶对应一个哈希链表,这样相同哈希值的键值对可以通过链表链接在一起。

3.代码实例

<1>.双向链表代码实例

#include <iostream>// 双向链表节点结构
struct list_head {struct list_head *next, *prev;
};int main() {// 创建双向链表struct list_head list;struct list_head node1, node2, node3;// 初始化双向链表头list.next = &node1;list.prev = &node3;// 初始化节点node1.next = &node2;node1.prev = &list;node2.next = &node3;node2.prev = &node1;node3.next = &list;node3.prev = &node2;// 遍历双向链表并打印节点地址struct list_head *pos;std::cout << "双向链表节点地址:";for (pos = list.next; pos != &list; pos = pos->next) {std::cout << pos << " ";}std::cout << std::endl;return 0;
}

<2>.哈希链表代码实例

#include <iostream>// 哈希链表头结构
struct hlist_head {struct hlist_node *first;
};// 哈希链表节点结构
struct hlist_node {struct hlist_node *next, **pprev;
};int main() {// 创建哈希链表struct hlist_head hash_table[10];struct hlist_node node1, node2, node3;// 初始化哈希链表头for (int i = 0; i < 10; ++i) {hash_table[i].first = NULL;}// 初始化节点node1.next = &node2;node1.pprev = &hash_table[0].first;node2.next = &node3;node2.pprev = &node1.next;node3.next = NULL;node3.pprev = &node2.next;// 遍历哈希链表并打印节点地址std::cout << "哈希链表节点地址:";struct hlist_node *hpos;for (hpos = hash_table[0].first; hpos != NULL; hpos = hpos->next) {std::cout << hpos << " ";}std::cout << std::endl;return 0;
}

这篇关于C++之双向链表与哈希链表用法区别实例(二百六十八)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/879145

相关文章

SpringBoot UserAgentUtils获取用户浏览器的用法

《SpringBootUserAgentUtils获取用户浏览器的用法》UserAgentUtils是于处理用户代理(User-Agent)字符串的工具类,一般用于解析和处理浏览器、操作系统以及设备... 目录介绍效果图依赖封装客户端工具封装IP工具实体类获取设备信息入库介绍UserAgentUtils

Java中的@SneakyThrows注解用法详解

《Java中的@SneakyThrows注解用法详解》:本文主要介绍Java中的@SneakyThrows注解用法的相关资料,Lombok的@SneakyThrows注解简化了Java方法中的异常... 目录前言一、@SneakyThrows 简介1.1 什么是 Lombok?二、@SneakyThrows

Python中的getopt模块用法小结

《Python中的getopt模块用法小结》getopt.getopt()函数是Python中用于解析命令行参数的标准库函数,该函数可以从命令行中提取选项和参数,并对它们进行处理,本文详细介绍了Pyt... 目录getopt模块介绍getopt.getopt函数的介绍getopt模块的常用用法getopt模

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Java中Scanner的用法示例小结

《Java中Scanner的用法示例小结》有时候我们在编写代码的时候可能会使用输入和输出,那Java也有自己的输入和输出,今天我们来探究一下,对JavaScanner用法相关知识感兴趣的朋友一起看看吧... 目录前言一 输出二 输入Scanner的使用多组输入三 综合练习:猜数字游戏猜数字前言有时候我们在

java解析jwt中的payload的用法

《java解析jwt中的payload的用法》:本文主要介绍java解析jwt中的payload的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解析jwt中的payload1. 使用 jjwt 库步骤 1:添加依赖步骤 2:解析 JWT2. 使用 N

Linux命令之firewalld的用法

《Linux命令之firewalld的用法》:本文主要介绍Linux命令之firewalld的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux命令之firewalld1、程序包2、启动firewalld3、配置文件4、firewalld规则定义的九大

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七