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

相关文章

Before和BeforeClass的区别及说明

《Before和BeforeClass的区别及说明》:本文主要介绍Before和BeforeClass的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Before和BeforeClass的区别一个简单的例子当运行这个测试类时总结Before和Befor

mapstruct中的@Mapper注解的基本用法

《mapstruct中的@Mapper注解的基本用法》在MapStruct中,@Mapper注解是核心注解之一,用于标记一个接口或抽象类为MapStruct的映射器(Mapper),本文给大家介绍ma... 目录1. 基本用法2. 常用属性3. 高级用法4. 注意事项5. 总结6. 编译异常处理在MapSt

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

MyBatis ResultMap 的基本用法示例详解

《MyBatisResultMap的基本用法示例详解》在MyBatis中,resultMap用于定义数据库查询结果到Java对象属性的映射关系,本文给大家介绍MyBatisResultMap的基本... 目录MyBATis 中的 resultMap1. resultMap 的基本语法2. 简单的 resul

Python主动抛出异常的各种用法和场景分析

《Python主动抛出异常的各种用法和场景分析》在Python中,我们不仅可以捕获和处理异常,还可以主动抛出异常,也就是以类的方式自定义错误的类型和提示信息,这在编程中非常有用,下面我将详细解释主动抛... 目录一、为什么要主动抛出异常?二、基本语法:raise关键字基本示例三、raise的多种用法1. 抛

C++作用域和标识符查找规则详解

《C++作用域和标识符查找规则详解》在C++中,作用域(Scope)和标识符查找(IdentifierLookup)是理解代码行为的重要概念,本文将详细介绍这些规则,并通过实例来说明它们的工作原理,需... 目录作用域标识符查找规则1. 普通查找(Ordinary Lookup)2. 限定查找(Qualif

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

java中Optional的核心用法和最佳实践

《java中Optional的核心用法和最佳实践》Java8中Optional用于处理可能为null的值,减少空指针异常,:本文主要介绍java中Optional核心用法和最佳实践的相关资料,文中... 目录前言1. 创建 Optional 对象1.1 常规创建方式2. 访问 Optional 中的值2.1